GaussDB数据库SQL系列:DROP & TRUNCATE & DELETE
目录
二、GaussDB的 DROP & TRUNCATE & DELETE 简述
一、前言
在数据库中,SQL作为一种常用的数据库编程语言,扮演着至关重要的角色。SQL不仅可以用于创建、修改和查询数据库,还可以通过DROP、DELETE和TRUNCATE等语句来删除数据。这些语句是SQL语言中的最常用的命令,且它们有着不同的含义和使用场景。
本文以GaussDB数据库为平台,将详细介绍SQL中DROP、TRUNCATE和DELETE等语句的含义、使用场景以及注意事项,帮助读者更好地理解和掌握这些常用的数据库操作命令。
二、GaussDB的 DROP & TRUNCATE & DELETE 简述
1、简述
- DROP语句可以删除整个表,包括表结构和数据等;
- TRUNCATE语句则可以快速地删除表中的所有数据,但不删除表结构。
- DELETE语句可以根据条件删除表中的数据,但不包括表结构;
2、命令比对
大类 | DROP | TRUNCATE | DELETE |
SQL类型 | DDL | DDL | DML |
删除内容 | 删除表的所有数据,包括表结构、索引和权限等 | 删除表中所有数据,或指定分区的数据 | 删除表的全部或部分(+条件)数据 |
执行速度 | 速度最快 | 速度中等 | 速度最慢 |
Tip:在GaussDB数据库中,DROP是用于定义或修改数据库中的对象的命令之一。对象主要包括:库、模式、表空间、表、索引、视图、存储过程、函数、加密秘钥等,本次只针对表的操作。
三、GaussDB的DROP TABLE命令及示例
1、功能描述
DROP TABLE的功能是用来删除已存在的Table。
2、语法
DROP TABLE [IF EXISTS] [db_name.]table_name;
说明:SQL中加[IF EXISTS] ,可以防止因表不存在而导致执行报错。
参数:db_name:Database名称。如果未指定,将选择当前database。table_name:需要删除的Table名称。
3、示例
以下示例演示DROP命令的使用,依次执行如下SQL语句:
--删除整个表course DROP TABLE IF EXISTS course --创建course表 CREATE TABLE course(cid VARCHAR(10),cname VARCHAR(10),teid VARCHAR(10)); --初始化数据 INSERT INTO course VALUES('01' , '语文' , '02'); INSERT INTO course VALUES('02' , '数学' , '01'); INSERT INTO course VALUES('03' , '英语' , '03'); --3条记录 SELECT count(1) FROM course; --删除整个表 DROP TABLE IF EXISTS course --查看结果,表不存在(表结构及数据不存在) SELECT count(1) FROM course;
1)DROP TABLE,提示表不存在
2)创建并初始化一张实验表
3)DROP TABLE 执行成功
4)查看执行结果
四、GaussDB的TRUNCATE命令及示例
1、功能描述
从表或表分区中移除所有数据,TRUNCATE快速地从表中删除所有行。它和在目标表上进行无条件的DELETE有同样的效果,但由于TRUNCATE不做表扫描,因而快得多, 且使用的系统和事务日志资源少。在大表上操作效果更明显。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。
2、语法
TRUNCATE [TABLE] table_name;
或
ALTER TABLE [IF EXISTS] table_name TRUNCATE PARTITION { partition_name | FOR ( partition_value [, ...] ) }
参数:table_name:需要删除数据的Table名称。partition_name:需要删除的分区表的分区名称。partition_value:需要删除的分区表的分区值。
3、示例1
以下示例演示TRUNCATE命令的使用:
--创建course表 DROP TABLE IF EXISTS course; CREATE TABLE course(cid VARCHAR(10),cname VARCHAR(10),teid VARCHAR(10)); --初始化数据 INSERT INTO course VALUES('01' , '语文' , '02'); INSERT INTO course VALUES('02' , '数学' , '01'); INSERT INTO course VALUES('03' , '英语' , '03'); --3条记录 SELECT count(1) FROM course; --清空表 TRUNCATE TABLE course; --或 TRUNCATE course; --0条记录 SELECT count(1) FROM course;
1)创建实验表并初始化数据
2)TRUNCATE TABLE执行成功
3)查看执行结果
4、示例2
以下示例演示TRUNCATE命令的删除分区表数据
--创建列表分区(LIST) DROP TABLE IF EXISTS orders; CREATE TABLE orders ( id INT PRIMARY KEY, customer_id INT, order_date DATE, product_id INT, quantity INT ) PARTITION BY LIST (customer_id) ( PARTITION p1 VALUES (100), PARTITION p2 VALUES (200), PARTITION p3 VALUES (300), PARTITION p4 VALUES (400), PARTITION p5 VALUES (500) ); --插入测试数据 INSERT INTO orders(id,customer_id,order_date,product_id,quantity)VALUES(1001,100,date'20230822',1,10); INSERT INTO orders(id,customer_id,order_date,product_id,quantity)VALUES(1002,100,date'20230822',2,20); INSERT INTO orders(id,customer_id,order_date,product_id,quantity)VALUES(1003,100,date'20230822',3,30); INSERT INTO orders(id,customer_id,order_date,product_id,quantity)VALUES(1004,200,date'20230822',4,40); --查看分区p1、p2的数据 SELECT * FROM orders WHERE customer_id IN (100,200); --或 --根据分区名称查询 SELECT * FROM orders PARTITION(p2); --清空分区p1。 ALTER TABLE orders TRUNCATE PARTITION p1; --或者 --清空分区p2=200。 ALTER TABLE orders TRUNCATE PARTITION for (200); --查看分区p1、p2的数据 SELECT * FROM orders WHERE customer_id IN (100,200);
1)创建实验表并初始化
2)根据分区进行删数据
五、GaussDB的DELETE命令及示例
1、功能描述
从指定的表里删除满足WHERE子句的行。如果WHERE子句不存在,将删除表中所有行,结果只保留表结构。
2、注意事项
- 不支持DELETE语句中使用LIMIT。应使用WHERE条件明确需要更新的目标行。
- 不支持在单条SQL语句中,对多个表进行删除。
- DELETE语句中必须有WHERE子句,避免全表扫描。
- DELETE语句中禁止不应使用ORDER BY、GROUP BY子句,避免不必要的排序。
- 如果需要清空一张表,建议使用TRUNCATE,而不是DELETE。
- TRUNCATE会创建新的物理文件,并在事务结束时将原文件物理删除,清空磁盘空间。而DELETE会将表中数据进行标记,直到VACCUUM FULL阶段才会真正清理磁盘空间。
- DELETE有主键或索引的表,WHERE条件应结合主键或索引,提高执行效率。
- DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。
- 如果想保留标识计数值,请改用 DELETE
3、语法
DELETE FROM table_name [WHERE condition];
参数:table_name:需要删除数据的Table名称。condition:用于判断哪些行需要被删除。
4、示例
复用前面的实验表:
DELETE FROM orders WHERE customer_id <200;
1)删除orders表中customer_id <200的所有数据:
六、应用场景
- 需要根据一定的业务条件删除数据时、且数据量、性能可控的情况下,可以考虑使用 DELETE。
- 需要删除大批量数据时,同时要求速度快,效率高并且无需撤销时,可以使用 TRUNCATE。
- 在企业级开发中,实际上都是进行逻辑删除(将数据进行“删除标识”处理)、而并不进行物理上的删除。
- 在实际生产环境中,一般情况下删除业务处理(过渡表)中的数据。
- 在实际企业开发、维护过程中,不管使用 DELETE、TRUNCATE还是DROP命令前,都要考虑数据的备份。
七、小结
在GaussDB等数据库中,DROP、TRUNCATE和DELETE均是常用的删除数据的命令。但在实际业务使用中,需要根据不同的需求进行准确的选择,但无论选择那种删数方式,都需要考虑数据安全性——重要的事情说三遍:备份!备份!备份!
——结束。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
快速理解DDD领域驱动设计架构思想-基础篇 | 京东物流技术团队
1 前言 本文与大家一起学习并介绍领域驱动设计(Domain Drive Design) 简称DDD,以及为什么我们需要领域驱动设计,它有哪些优缺点,尽量用一些通俗易懂文字来描述讲解领域驱动设计,本篇并不会从深层大论述讲解落地实现,这些大家可以在了解入门后再去深层次学习探讨或在后续进阶和高级篇了解,希望通过本文介绍,可以让大家快速了解DDD并有一个基础的认知,DDD本身就是理论的集合,很难在不积累理论情况下来有效的实施DDD,仅仅看一些代码案例后就开搞,最终出来东西也是东施效颦,莫要好高骛远。 最后期望大家在工作中能多思考,如你所负责项目如果用DDD如何设计、以及会面临哪些挑战。 学习了解DDD之前,期望大家可在温顾下以往我们所了解掌握一些知识,努力让自己所学所掌握的内容沉淀下来,推荐阅读系列。 Head First 设计模式:基础面向对象概念和重要的设计模式; UML面向对象建模基础:从需求到分析,从分析到设计,从设计到编码,UML都有用武之地 实现领域驱动设计:很厚,更加务实,推荐阅读 领域驱动设计:张逸-DDD开山之作,挺玄幻的,多读几遍受益匪浅; 2 定义与概念 领域驱动设计(...
- 下一篇
弹性数据库连接池探活策略调研(一)——HikariCP | 京东云技术团队
调研背景: 数据库连接建立是比较昂贵的操作(至少对于 OLTP),不仅要建立 TCP 连接外还需要进行连接鉴权操作,所以客户端通常会把数据库连接保存到连接池中进行复用。连接池维护到弹性数据库(JED)的长连接,弹性数据库默认不会主动关闭客户端连接(除非报错),但一般客户端到弹性数据库之间还会有负载均衡代理,它们通常为了节约连接资源会在连接空闲10分钟后主动清理连接,释放无用的连接资源。这就导致一些用户的连接池探活参数配置不当,进而拿到是已经失效的连接。客户端就会报以下错误: 基于以上的背景我们根据Java应用常用的连接池的常用版本的连接池探活相关的功能进行了调研,并对每个版本提供了JED配置的模版。目前,常用的连接池版本如下: HikariCP 3.2.0、 3.4.5、4.0.3 DRUID 1.1.10、1.1.9、1.0.9 DBCP 1.4 、2.2.0、2.1.1 HikariCP 我们第一个章节先来介绍一下HikariCP连接池探活相关的内容: HikariCP连接池会在需要分配连接对象给应用程序使用时,先检查连接对象的状态。为了检测连接是否可用,连接池会调用isConne...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Linux系统CentOS6、CentOS7手动修改IP地址
- 2048小游戏-低调大师作品
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS8编译安装MySQL8.0.19
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2更换Tomcat为Jetty,小型站点的福音