4.3 INSERT/DELETE命令__第四章 DML_使用手册_分析型数据库-阿里云
如果一个表是实时写入的表,则分析型数据库会支持对该表的单条数据进行Insert/Delete操作,不过由于分析型数据库不支持事务,对于Insert/Delete命令,有一些限制。
在分析型数据库中Insert语句的语法是:
INSERT [IGNORE]
INTO tbl_name (col1,col2...)
VALUES (value1, value2...), (value1, value2...)....
在分析型数据库中,能够实时插入的表一定要定义主键或组合主键,和MySQL有一个非常大的不同是,分析型数据库在进行数据插入时,若发现同主键的数据时,默认执行覆盖行为。若使用insert ignore语法,则在发现有同主键的数据时,丢弃新插入的数据,保留原有数据。但是无论如何,在主键冲突时分析型数据库无法直接返回错误给insert的执行方。
在分析型数据库中的Delete语句的语法是:
DELETE FROM tbl_name WHERE where_definition
where_definition中暂不支持函数定义。
对分析型数据库是数据插入和删除操作,原则上在分析型数据库操作返回成功后一分钟内可查(但不保证一定是一分钟的数据可见延迟),不过在表刚刚创建时的十分钟内,数据可能无法查询。
Delete语句执行后,数据会不可查询到,但不会在物理上立刻删除,原则上24小时内会自动清除掉,如果删除了大量数据想立刻生效,可以执行:
optimize table <tablename>;
执行成功一段时间后,物理上数据会被删除。
关于最终一致性:对于主键相同的数据的多次变更,分析型数据库会遵循分析型数据库返回语句执行成功的顺序进行;对于主键不同的数据的两次变更,分析型数据库不保证先执行的变更会比后执行的变更更优先的查询到。但是当业务端暂停数据写入的若干时间后,分析型数据库会保证数据的最终一致。
若希望达成数据写入速率的最大化,建议:
(1)每条insert插入多条数据,具体条数视数据列数决定。若需要极限性能,每条insert插入的数据需拥有相同的一级分区号(后续分析型数据库提供SDK帮助客户达成此要求);(2)每购买一个c1/c8 ECU,客户端可增加20-30个并发连接插入数据。
最后更新:2016-11-24 11:23:46
上一篇:
4.2 逻辑表达式和特殊语法__第四章 DML_使用手册_分析型数据库-阿里云
下一篇:
4.4 多计算引擎和Hint__第四章 DML_使用手册_分析型数据库-阿里云
主题通知方式接收消息__接收消息通知_开发人员指南_视频点播-阿里云
CID 投递统计__发布订阅统计接口_Open API_消息队列 MQ-阿里云
搜索测试__产品使用手册_开放搜索-阿里云
云服务器 ECS 故障处理 CPU跑满
通知__使用须知_用户指南_弹性伸缩-阿里云
GetMachineGroup__Logtail机器组相关接口_API-Reference_日志服务-阿里云
刷新作业状态__作业管理_SDK参考手册_数据集成-阿里云
TXC 简介__TXC for EDAS_二方服务_企业级分布式应用服务 EDAS-阿里云
BandwidthPackageMonitorDataSetType__数据类型_API参考_专有网络 VPC-阿里云
播放地址__使用手册_视频直播-阿里云
相关内容
常见错误说明__附录_大数据计算服务-阿里云
发送短信接口__API使用手册_短信服务-阿里云
接口文档__Android_安全组件教程_移动安全-阿里云
运营商错误码(联通)__常见问题_短信服务-阿里云
设置短信模板__使用手册_短信服务-阿里云
OSS 权限问题及排查__常见错误及排除_最佳实践_对象存储 OSS-阿里云
消息通知__操作指南_批量计算-阿里云
设备端快速接入(MQTT)__快速开始_阿里云物联网套件-阿里云
查询API调用流量数据__API管理相关接口_API_API 网关-阿里云
使用STS访问__JavaScript-SDK_SDK 参考_对象存储 OSS-阿里云