使用过Oracle的都知道,Truncate操作由于不需要写redo日志,因此,在性能上会比delete操作更高效,但在实际使用过程中,有时会发现delete比truncate速度更快。以下介绍下二者的机制,让大家对二者有清晰的了解。

一、大数据量删除操作

1、数据准备

创建两张没有索引的大表:t1 , t2 ,每张表的数据量接近 350W

test=# create table t2 as select * from t1;
SELECT 3461120

2、测试Delete操作

test=# checkpoint;
CHECKPOINT test=# select pg_current_wal_lsn();
pg_current_wal_lsn
--------------------
0/92DB1FC8
(1 row) test=# select relname,relfilenode from sys_class where relname='t1';
relname | relfilenode
---------+-------------
t1 | 16575
(1 row) test=# delete from t1;
DELETE 3461120
Time: 4771.554 ms (00:04.772) test=# select pg_current_wal_lsn();
pg_current_wal_lsn
--------------------
0/C87A2EC0
(1 row) test=# select pg_wal_lsn_diff('0/C87A2EC0','0/92DB1FC8');
pg_wal_lsn_diff
-----------------
899616504
(1 row)

test=# checkpoint;
CHECKPOINT

test=# select relname,relfilenode from sys_class where relname='t1';
relname | relfilenode
---------+-------------
t1 | 16575
(1 row)

结论:Delete 操作产生了近900M的日志;数据文件的relfilenode 不变。

3、测试Truncate操作

test=# checkpoint;
CHECKPOINT test=# select relname,relfilenode from sys_class where relname='t2';
relname | relfilenode
---------+-------------
t2 | 16581
(1 row) test=# select pg_current_wal_lsn();
pg_current_wal_lsn
--------------------
0/CAA7C678
(1 row) test=# truncate table t2;
TRUNCATE TABLE
Time: 84.124 ms test=# select pg_current_wal_lsn();
pg_current_wal_lsn
--------------------
0/CAA82D40
(1 row) Time: 0.327 ms
test=# select relname,relfilenode from sys_class where relname='t2';
relname | relfilenode
---------+-------------
t2 | 16587
(1 row) Time: 0.491 ms
test=# select pg_wal_lsn_diff('0/CAA82D40','0/CAA7C678');
pg_wal_lsn_diff
-----------------
26312
(1 row) Time: 1.239 ms

结论:Truncate 操作基本不产生redo;relfilenode 会变化,这是由于truncate操作相当于新建了个文件。

三、小数据量删除操作比较

1、比较一:数据未写回磁盘前,进行truncate

test=# declare
test-# v_sql text;
test-# begin
test-# for i in 1..1000 loop
test-# drop table if exists t1;
test-# create table t1 as select * from pg_class;
test-# delete from t1;
test-# end loop;
test-# end;
test-# /
ANONYMOUS BLOCK
Time: 7173.891 ms (00:07.174) test=# declare
test-# v_sql text;
test-# begin
test-# for i in 1..1000 loop
test-# drop table if exists t1;
test-# create table t1 as select * from pg_class;
test-# truncate t1;
test-# end loop;
test-# end;
test-# /
ANONYMOUS BLOCK
Time: 7477.366 ms (00:07.477)

结论:truncate 似乎更慢。从操作系统IO看,二者的IO 相差不大。

可能原因:truncate 在操作系统层面的操作实际删除旧文件,新建新文件。当调用操作系统命令删除旧文件时,需要将数据先写回文件,才能删除。而本例中,实际从create table 到truncate 时间很短,数据还未写回文件。

2、测试二:先建表,在删除数据

declare
v_sql text;
begin
for i in 1..1000 loop
v_sql = 'drop table if exists t'||i;
execute immediate v_sql;
v_sql = 'create table t'||i||' as select * from pg_class';
execute immediate v_sql;
end loop;
end; checkpoint; declare
v_sql text;
begin
for i in 1..1000 loop
v_sql = 'delete from t'||i;
execute immediate v_sql;
end loop;
end;
/
ANONYMOUS BLOCK
Time: 3412.780 ms (00:03.413) declare
v_sql text;
begin
for i in 1..1000 loop
v_sql = 'truncate t'||i;
execute immediate v_sql;
end loop;
end;
/
ANONYMOUS BLOCK
Time: 1268.753 ms (00:01.269)

结论:先建表,再checkpoint ,将数据写回数据文件。然后,再比较Delete 和 Truncate 操作,可以看到即使小表,truncate 操作也快很多。

KingbaseES Truncate 与 Delete 机制比较的更多相关文章

  1. sql中 truncate 、delete与drop区别

    相同点: 1.truncate和不带where子句的delete.以及drop都会删除表内的数据. 2.drop.truncate都是DDL语句(数据定义语言),执行后会自动提交. 不同点: 1. t ...

  2. truncate 、delete与drop区别

    原博文地址:http://www.cnblogs.com/8765h/archive/2011/11/25/2374167.html 相同点: 1.truncate和不带where子句的delete. ...

  3. sql语句中----删除表数据drop、truncate和delete的用法

    sql语句中----删除表数据drop.truncate和delete的用法 --drop drop table  tb   --tb表示数据表的名字,下同 删除内容和定义,释放空间.简单来说就是把整 ...

  4. [转]mysql drop、truncate和delete比较

    一.drop table tb drop将表格直接删除,没有办法找回. 立刻释放磁盘空间 ,不管是 Innodb和MyISAM . 二.truncate (table) tb 该命令可以清空一个表里的 ...

  5. truncate与delete的区别

    TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行.但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源 ...

  6. sql之truncate 、delete与drop区别

    sql之truncate .delete与drop区别相同点:truncate 和不带 where 子句的 delete,以及 drop 一定会删除表内的数据不同点:1. truncate 和 del ...

  7. 删除表数据drop、truncate和delete的用法

    说到删除表数据的关键字,大家记得最多的可能就是delete了 然而我们做数据库开发,读取数据库数据.对另外的两兄弟用得就比较少了 现在来介绍另外两个兄弟,都是删除表数据的,其实也是很容易理解的 老大- ...

  8. sql server 中删除表中数据truncate和delete的区别(转载自.net学习网)

    我们都知道truncate table可以用来删除整个表的内容,它与delete后面不跟where条件的效果是一样.但除此之外,我们还清楚它们之间有其它的区别吗?本章我们将一起讨论truncate与d ...

  9. TRUNCATE,DORP,DELETE

    TRUNCATE,DORP,DELETE 相同点: truncate和不带where子句的delete, 以及drop都会删除表内的数据 不同点: 1. truncate和 delete只删除数据不删 ...

随机推荐

  1. cve-2021-42287和cve-2021-42278漏洞复现

    一.漏洞概述 cve-2021-42287 : 由于Active Directory没有对域中计算机与服务器账号进行验证,经过身份验证的攻击 者利用该漏洞绕过完全限制,可将域中普通用户权限提升为域管理 ...

  2. skywalking链路监控

    1. 下载安装包官网地址:http://skywalking.apache.org/downloads/ 2. tar xzf apache-skywalking-apm-6.5.0.tar.gz - ...

  3. 不要使用短路逻辑编写 stl sorter 多条件比较

    前言 最近工期紧.任务多,没有时间更新博客,就水一期吧.虽然是水,也不能太水,刚好最近工作中遇到一个 sorter 多条件排序的问题,花费了半天时间来定位解决,就说说它吧. 背景 公司产品是一个跨端的 ...

  4. FS2K人脸素描属性识别

    人脸素描属性识别 代码:https://github.com/linkcao/FS2K_extract 问题分析 需要根据FS2K数据集进行训练和测试,实现输入一张图片,输出该图片的属性特征信息,提取 ...

  5. 扩展新的WCV到标准的WC后,不能在业务角色里面看见视图解决方法

    by zyi 感谢群主红枣的分享 1.把你的WCVIEW扩展进WC中 2.使用UI Designer打开你的WCVIEW 3.更改你的WCVIEW名字

  6. 016(剪花布条)(KMP)

    题目:http://ybt.ssoier.cn:8088/problem_show.php?pid=1465 题目思路:KMP模板题,该说的都在代码里 #include<bits/stdc++. ...

  7. UI自动化测试执行问题总结

    ------------恢复内容开始------------ ![image](https://img2022.cnblogs.com/blog/1510476/202206/1510476-2022 ...

  8. JUC源码学习笔记1——AQS和ReentrantLock

    笔记主要参考<Java并发编程的艺术>并且基于JDK1.8的源码进行的刨析,此篇只分析独占模式,后续在ReentrantReadWriteLock和 CountDownLatch中 会重点 ...

  9. P2183 [国家集训队]【一本通提高组合数学】礼物

    [国家集训队]礼物 题目背景 一年一度的圣诞节快要来到了.每年的圣诞节小 E 都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小 E 心目中的重要性不同,在小 E 心中分量越重的人,收到的礼物会 ...

  10. Lua 语言

    # Lua是一种轻量.小巧的脚本语言,用标准C语言编写并以源码形式开发.设计的摸底是为了嵌入到其他应用程序中,从而为应用程序提供灵活的拓展和定制功能. # Lua安装 # 官网:https://www ...