当前位置: 首页 > news >正文

建一个推广网站价格搜索引擎优化师工资

建一个推广网站价格,搜索引擎优化师工资,wordpress 空行,手机桌面布局设计软件clickhouse不擅长更新和删除操作,更新操作很重,更新是重新创建一个分区,更新完后,太混之前的 ClickHouse提供了DELETE和UPDATE的能力,这类操作被称为Mutation查询,它可以看作ALTER语句的变种。虽然Mutation…

clickhouse不擅长更新和删除操作,更新操作很重,更新是重新创建一个分区,更新完后,太混之前的
ClickHouse提供了DELETE和UPDATE的能力,这类操作被称为Mutation查询,它可以看作ALTER语句的变种。虽然Mutation能最终实现修改和删除,但不能完全以通常意义上的UPDATE和DELETE来理解,我们必须清醒地认识到它的不同:首先,Mutation语句是一种“很重”的操作,更适用于批量数据的修改和删除;其次,它不支持事务,一旦语句被提交执行,就会立刻对现有数据产生影响,无法回滚;最后,Mutation语句的执行是一个异步的后台过程,语句被提交之后就会立即返回。所以这并不代表具体逻辑已经执行完毕,它的具体执行进度需要通过system.mutations系统表查询。注意数据的修改和删除操作是使用MergeTree家族引擎:
ALTER TABLE test_ud
DELETE WHERE id = ‘1’
Received exception from server (version 20.8.3):
Code: 48. DB::Exception: Received from localhost:9000. DB::Exception: Mutations are not supported by storage Log.
删除数据语法:
ALTER TABLE [db_name.]table_name DELETE WHERE filter_expr
示例:
CREATE TABLE test_ud
(
id String,
name String,
job String
)
ENGINE = MergeTree
ORDER BY id;
insert into test_ud values (1,‘zhangsan’,‘coder’) ;
insert into test_ud values (2,‘lisi’,‘coder’) ;
删除数据:
ALTER TABLE test_ud
DELETE
WHERE id = ‘1’
查询数据:
SELECT *
FROM test_ud

查看表存储数据的目录,我们发现表的目录下多出一个文件

修改数据语法,修改数据支持同时修改多个字段
ALTER TABLE [db_name.]table_name UPDATE column1 = expr1 [, …] WHERE filter_expr
ALTER TABLE test_ud
UPDATE name = ‘my’, job = ‘teacher’ WHERE id = ‘2’ ; --但是注意的时候一定指定where条否则会报错,这种语法的where条件也可以使用子查询 ;
查看mutation队列
那么,怎么查看数据是否更新完成了呢?
可以通过system.mutations表查看相关信息:
SELECT
database,
table,
command,
create_time,
is_done
FROM system.mutations
ORDER BY create_time DESC
LIMIT 10;

database: 库名
table: 表名
command: 更新/删除语句
create_time: mutation任务创建时间,系统按这个时间顺序处理数据变更
is_done: 是否完成,1为完成,0为未完成
通过以上信息,可以查看当前有哪些mutation已经完成,is_done为1即表示已经完成。
Mutation具体过程
首先,使用where条件找到需要修改的分区;
然后,重建每个分区,用新的分区替换旧的,分区一旦被替换,就不可回退;
对于每个分区,可以认为是原子性的;但对于整个mutation,如果涉及多个分区,则不是原子性的。
注意事项
更新功能不支持更新有关主键或分区键的列
更新操作没有原子性,即在更新过程中select结果很可能是一部分变了,一部分没变,从上边的具体过程就可以知道
更新是按提交的顺序执行的
更新一旦提交,不能撤销,即使重启clickhouse服务,也会继续按照system.mutations的顺序继续执行
已完成更新的条目不会立即删除,保留条目的数量由finished_mutations_to_keep存储引擎参数确定。超过数据量时旧的条目会被删除
更新可能会卡住,比如update intvalue='abc’这种类型错误的更新语句执行不过去,那么会一直卡在这里,此时,可以使用KILL MUTATION来取消,语法:
kill mutation where database=‘app’ and table=‘test’ // database、table是system.mutations表中的字段
使用建议
按照官方的说明,update/delete的使用场景是一次更新大量数据,也就是where条件筛选的结果应该是一大片数据。
举例:alter table test update status=1 where status=0 and day=‘2020-04-01’,一次更新一天的数据。
那么,能否一次只更新一条数据呢?例如:alter table test update pv=110 where id=100
当然也可以,但频繁的这种操作,可能会对服务造成压力。这很容易理解,如上文提到,更新的单位是分区,如果只更新一条数据,那么需要重建一个分区;如果更新100条数据,而这100条可能落在3个分区上,则需重建3个分区;相对来说一次更新一批数据的整体效率远高于一次更新一行。
对于频繁单条更新的这种场景,建议使用ReplacingMergeTree/CollapsingMergeTree引擎来变相解决。

http://www.mmbaike.com/news/67792.html

相关文章:

  • 网站建设需求计划宁波网络推广运营公司电话
  • 最近国际军事军情要闻游戏优化大师
  • 怎么做贝店式的网站微信投放广告多少钱
  • 东莞设计网站推荐怎样打小广告最有效
  • 网站建设案例百度云网站推广教程
  • 现在没人做网站了关键词优化建议
  • php可以做网站吗百度营销客户端
  • 怎样做可以连接服务器的网站个人网站建站教程
  • 北京网站网页设计seo优化是指
  • 做网站后台学什么专业珠海网站建设
  • 苏州做网站品牌公司网址查询域名解析
  • 网站设计遇到的问题seo设置是什么
  • php网站开发图文教程网页版百度云
  • 小说类网站功能建设网站制作的要点和步骤详解
  • 公司怎么做网站平台seo网页优化培训
  • html5网站开发seo教程免费
  • 企业邮箱怎么找深圳seo教程
  • 株洲网站制作公司有哪些百度域名注册官网
  • 政府网站建设认识不足短视频拍摄剪辑培训班
  • 网站一般字体搜索引擎营销方法
  • 怎么能查到网站是哪个公司做的企业网站seo
  • tk网站域名关键词的优化和推广
  • asp.net网站开发技术企业网络营销推广案例
  • 有关于网站建设的论文seo研究中心论坛
  • 网站建设基本步骤白帽优化关键词排名seo
  • 网站建设方案费用预算长春做网站公司长春seo公司
  • 深圳信科做网站营销技巧第三季
  • 闵行18路优化最狠的手机优化软件
  • web开发前端框架seo资源咨询
  • 有源码做网站网络营销策划书包括哪些内容