表格存储 SQL 操作实战

本文涉及的产品
表格存储 Tablestore,50G 2个月
简介: 表格存储做为一款结构化存储系统,近期发布了新功能 SQL,大幅简化了查询的门槛,用户无需学习繁琐的 SDK,也不用区分表,索引等不同的接口,可以像访问传统的 MySQL 这类数据库一样,使用 SQL 的方式访问云原生的结构化大数据存储。下面我们就来具体实操下,看看查询用起来顺不顺手。

开篇

表格存储做为一款结构化存储系统,近期发布了新功能 SQL,大幅简化了查询的门槛,用户无需学习繁琐的 SDK,也不用区分表,索引等不同的接口,可以像访问传统的 MySQL 这类数据库一样,使用 SQL 的方式访问云原生的结构化大数据存储。下面我们就来具体实操下,看看查询用起来顺不顺手。

操作举例

话不多说我们就开始进入表格存储的控制台进行一番操作。

实例详情页

这里我们准备了两张订单表。右上角有 SQL 查询 标签,点击这里即可进入我们的 SQL 查询页面。

SQL 查询页面

1. 表绑定


进入页面,你会发现,在数据库“sqltest” 下面并没有表,不用慌,这是因为这些表不是通过 SQL 引擎创建出来的,本身表格存储并不要求您定义完整的表 Schema,即 Schema free 的灵活方式,但是为了实现 SQL 查询,我们需要这里定义一下 Schema,注意这里的定义不会影响你的线上非 SQL 写入,只会给 SQL 查询用,您可以放心的设置。点击➕图标,可以选择一个表,我们会帮您生成一个默认的创建定义SQL Schema的模板,语法和创建物理表是一样的。

你可以根据需求去添加,删除 Create Table 中的列,注意数据类型的映射关系可以参考数据类型映射
很快我们绑定好两张表后,就可以开始体验查询了。

2. 查看绑定信息

这里可以查看到您之前的绑定信息,同时在OTS中的主键也会提示出来。主键会和后续我们的查询性能有很大的关系。

3. 查看索引



索引也会对查询性能有很大影响,后面随着我们的查询会在详细解释。

4. 体验查询

点查

熟悉表格存储的同学应该知道,ots 中有一个查询接口叫 GetRow,那什么样的SQL会类似点查的效果呢。

select * from ordertable where `order` = '0000004bf78d' and orderid = 'o132042352'

当我们的 SQL where 条件中,包含了所有的pk,并且用 = 确定具体 pk 的值,这时候就会触发我们的点查。以上面的 SQL 为例。针对这类点查,我们的 SQL 引擎可以承载高并发低延时的访问,这个和我们的存储引擎有着同样的特性。

范围查询

select * from ordertable where `order` >= '0000004bf78d' limit 100

当你的查询指定的是部分主键,或者主键有返回,那么就会变成表格存储的RangeScan进行查询。

范围查询和过滤

select * from ordertable where `order` >= '0000004bf78d' and salespersonid = 's0065' limit 100

指定了属性列的一些条件,就会添加过滤条件。

注意这里,可能会有多次数据和存储进行交互,因为可能需要持续扫描,以这个为例,我们扫描出100条满足条件得到数据花费了1.1s。

扫描数据超限

SQL 查询相对表格存储之前的固定pk方式的扫描要灵活许多,所以可能会遇到一些问题,例如您的查询因为没有合理指定条件,导致了全表大范围的扫描,这里我们对您的存储和消耗资源做了保护,对于一些大的查询我们进行了限制。例如:

select * from ordertable where `order` >= '0000004bf78d' and salespersonid = 's0065' order by ordertime limit 100

这样的请求可能会扫很多数据过滤然后在进行排序才能返回结果,此时就会触发我们的超限。
控制台会看到如下错误提示:

这里我们只是做了保护,具体的限制项可以参考我们的官网文档,SQL使用限制,如果希望更大规模的数据计算需求,可以联系我们。

5. 索引加速

上面最后一个例子,我们会发现有些场景跑起来会比较慢因为要扫描很多数据,又或者直接超过了我们的扫描数据上限。那是不是就束手无策了呢?那既然您看到这里,我们肯定会给您一个优化的方案就是:创建多元索引。

统计表行数


约10亿行数据,进行一次全表count,1.7秒。

基于属性列的过滤

可以看到查询还是非常快的,这是因为有了多元索引后,我们的 SQL 查询过滤条件会被下推到存储层,减少数据的扫描和传输。
那这时候你可能会问如果我带一些聚合查询会快么,那我们来尝试一发:

统计聚合

一些聚合函数也都可以在秒级别返回。
这是因为我们的聚合函数,groupby 也下推进入存储索引层,加速了整个过程中的数据传输损耗等。

小结

如果你的查询多基于 pk,可以直接通过绑定表进行数据操作了。如果你的条件相对比较灵活,又或者有一些聚合计算需求,推荐你创建我们的多元索引,然后可以体验到毫秒到秒级别的 SQL 查询体验啦!

最后欢迎扫码加群和我们一起讨论你的使用反馈!

更详细的功能介绍,欢迎参考表格存储官网文档,可以查看具体的 SQL 语法,用例,限制项等。
想了解更多表格存储的用法或者咨询欢迎加群讨论:
我们的开发者技术交流群,可搜索群号『11789671』或『23307953』,亦可直接扫码加入。

相关实践学习
消息队列+Serverless+Tablestore:实现高弹性的电商订单系统
基于消息队列以及函数计算,快速部署一个高弹性的商品订单系统,能够应对抢购场景下的高并发情况。
阿里云表格存储使用教程
表格存储(Table Store)是构建在阿里云飞天分布式系统之上的分布式NoSQL数据存储服务,根据99.99%的高可用以及11个9的数据可靠性的标准设计。表格存储通过数据分片和负载均衡技术,实现数据规模与访问并发上的无缝扩展,提供海量结构化数据的存储和实时访问。 产品详情:https://www.aliyun.com/product/ots
目录
相关文章
|
2月前
|
SQL 数据库 UED
SQL性能提升秘籍:5步优化法与10个实战案例
在数据库管理和应用开发中,SQL查询的性能优化至关重要。高效的SQL查询不仅可以提高应用的响应速度,还能降低服务器负载,提升用户体验。本文将分享SQL优化的五大步骤和十个实战案例,帮助构建高效、稳定的数据库应用。
76 3
|
2月前
|
SQL 缓存 监控
SQL性能提升指南:五大优化策略与十个实战案例
在数据库性能优化的世界里,SQL优化是提升查询效率的关键。一个高效的SQL查询可以显著减少数据库的负载,提高应用响应速度,甚至影响整个系统的稳定性和扩展性。本文将介绍SQL优化的五大步骤,并结合十个实战案例,为你提供一份详尽的性能提升指南。
56 0
|
3月前
|
SQL 关系型数据库 MySQL
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
|
3月前
|
SQL 数据处理 数据库
SQL语句优化与查询结果优化:提升数据库性能的实战技巧
在数据库管理和应用中,SQL语句的编写和查询结果的优化是提升数据库性能的关键环节
|
3月前
|
SQL 监控 关系型数据库
SQL语句性能分析:实战技巧与详细方法
在数据库管理中,分析SQL语句的性能是优化数据库查询、提升系统响应速度的重要步骤
|
3月前
|
SQL 关系型数据库 Serverless
sql注入原理与实战(四)数据表操作
sql注入原理与实战(四)数据表操作
|
3月前
|
SQL 存储 Java
sql注入原理与实战(二)数据库原理
sql注入原理与实战(二)数据库原理
|
3月前
|
SQL 前端开发 安全
sql注入原理与实战(一)
sql注入原理与实战(一)
|
5月前
|
SQL 存储 数据处理
"SQL触发器实战大揭秘:一键解锁数据自动化校验与更新魔法,让数据库管理从此告别繁琐,精准高效不再是梦!"
【8月更文挑战第31天】在数据库管理中,确保数据准确性和一致性至关重要。SQL触发器能自动执行数据校验与更新,显著提升工作效率。本文通过一个员工信息表的例子,详细介绍了如何利用触发器自动设定和校验薪资,确保其符合业务规则。提供的示例代码展示了在插入新记录时如何自动检查并调整薪资,以满足最低标准。这不仅减轻了数据库管理员的负担,还提高了数据处理的准确性和效率。触发器虽强大,但也需谨慎使用,以避免复杂性和性能问题。
73 1
|
6月前
|
SQL 安全 数据库
Python Web开发者必学:SQL注入、XSS、CSRF攻击与防御实战演练!
【7月更文挑战第26天】在 Python Web 开发中, 安全性至关重要。本文聚焦 SQL 注入、XSS 和 CSRF 这三大安全威胁,提供实战防御策略。SQL 注入可通过参数化查询和 ORM 框架来防范;XSS 则需 HTML 转义用户输入与实施 CSP;CSRF 防御依赖 CSRF 令牌和双重提交 Cookie。掌握这些技巧,能有效加固 Web 应用的安全防线。安全是持续的过程,需贯穿开发始终。
101 1
Python Web开发者必学:SQL注入、XSS、CSRF攻击与防御实战演练!