今天群里面讨论,DDL 还是 DML,我这种小白还是总结下他们的区别吧。

1. DDL – Data Definition Language

数据库定义语言:定义数据库的结构。

其主要命令有CREATE,ALTER,DROP等,下面用例子详解。该语言不需要commit,因此慎重。

CREATE – to create objects in the database   在数据库创建对象

例:CREATE DATABASE test; // 创建一个名为test的数据库

ALTER – alters the structure of the database   修改数据库结构

例:ALTER TABLE test ADD birthday date; // 修改test表,新增date类型的birthday列

DROP – delete objects from the database   从数据库中删除对象

例:DROP DATABASE test;// 删除test数据库

还有其他的:

TRUNCATE – 截断表内容(开发期,还是挺常用的)

COMMENT – 为数据字典添加备注

2. DML – Data Manipulation Language

数据库操作语言:SQL中处理数据库中的数据

其主要命令有SELECT,INSERT,UPDATE,DELETE等,这些例子大家常用就不一一介绍了。该语言需要commit。还有常用的 LOCK TABLE ,记得写过锁的博客 – 传送门

还有其他不熟悉的:

CALL – 调用一个PL/SQL或Java子程序
EXPLAIN PLAN – 解析分析数据访问路径

3. DCL – Data Control Language

数据库控制语言:授权,角色控制等

GRANT – 为用户赋予访问权限

REVOKE – 撤回授权权限

4. TCL – Transaction Control Language

事务控制语言

COMMIT – 保存已完成的工作

SAVEPOINT – 在事务中设置保存点,可以回滚到此处

ROLLBACK – 回滚

SET TRANSACTION – 改变事务选项

例子:Java中JDBC封装了对事务的支持。比如我们首先新建一个表:test

test.sql

SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;-- ----------------------------
--  Table structure for `city`
-- ----------------------------
DROP TABLE IF EXISTS `city`;
CREATE TABLE `city` (`id` int(11) NOT NULL DEFAULT '0' COMMENT '城市ID',`name` varchar(20) DEFAULT NULL COMMENT '名称',`state` varchar(20) DEFAULT NULL COMMENT '状态',`country` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;SET FOREIGN_KEY_CHECKS = 1;

JDBC事务回滚第一个例子 -JDBC数据库事务回滚:

/*** 描述:JDBC数据库事务回滚** Created by bysocket on 16/6/6.*/
public class TransactionRollBack extends BaseJDBC {public static void main(String[] args) throws SQLException {Connection conn = null;try {// 加载数据库驱动Class.forName(DRIVER);// 数据库连接conn = DriverManager.getConnection(URL,USER,PWD);// 关闭自动提交的事务机制conn.setAutoCommit(false);// 设置事务隔离级别 SERIALIZABLEconn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);Statement stmt = conn.createStatement();int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')");rows = stmt.executeUpdate("UPDATE city set country = 'TAIWAN' WHERE id = 4");// 提交事务conn.commit();} catch (Exception e) {e.printStackTrace();// 回滚事务if (conn != null) {conn.rollback();}} finally {/** 关闭数据库连接 */if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}}
}

第 19 行:设置了事务隔离级别为 SERIALIZABLE 底层调用的是TCL语言的SET TRANSACTION

第 22 行:执行通过,插入数据

第 23 行:执行不通过,没有主键为4的记录,直接抛出异常

第 31 行:事务回滚,封装的就是 TCL 语句的ROLLBACK

休息下,一个例子不够,再来一个。代码都在github主页上。https://github.com/JeffLi1993/jee-component-learning

JDBC事务回滚第二个例子-JDBC数据库事务回滚,回滚到特定的保存点:

/*** 描述:JDBC数据库事务回滚,回滚到特定的保存点** Created by bysocket on 16/6/6.*/
public class TransactionRollBack2 extends BaseJDBC {public static void main(String[] args) throws SQLException {Connection conn = null;Savepoint svpt = null;try {// 加载数据库驱动Class.forName(DRIVER);// 数据库连接conn = DriverManager.getConnection(URL,USER,PWD);// 关闭自动提交的事务机制conn.setAutoCommit(false);// 设置事务隔离级别 SERIALIZABLEconn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);Statement stmt = conn.createStatement();int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')");// 设置事务保存点svpt = conn.setSavepoint();rows = stmt.executeUpdate("UPDATE city set country = 'TAIWAN' WHERE id = 4");// 提交事务conn.commit();} catch (Exception e) {e.printStackTrace();// 回滚事务if (conn != null) {conn.rollback(svpt);}} finally {/** 关闭数据库连接 */if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}}
}

和第一个例子重复的就不提了。

第 9 行:声明了一个保存点

第 24 行:设置了保存点

第 33 行:回滚事务到该保存点

上面的代码涉及到的是 TCL语言中的 SAVEPOINT

最后来张图总结:

转载自 并发编程网 - ifeve.com

数据库必会必知 之 SQL四种语言:DDL DML DCL TCL相关推荐

  1. SQL四种语言:DDL,DML,DCL,TCL

    1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...

  2. SQL 四大功能DDL/DML/DCL/TCL

    SQL主要分成四部分: (1)数据定义.(SQL DDL)用于定义SQL模式.基本表.视图和索引的创建和撤消操作. (2)数据操纵.(SQL DML)数据操纵分成数据查询和数据更新两类.数据更新又分成 ...

  3. 数据库,结构化查询语言的四种语言

    SQL四种语言:DDL,DML,DCL,TCL 1.DDL(Data Definition Language)数据库定义语言statements are used to define the data ...

  4. Python|SQL详解之DDL|DML|DQL|DCL|索引|视图、函数和过程|JSON类型|窗口函数|接入MySQL|清屏|正则表达式|executemany|语言基础50课:学习(14)

    文章目录 系列目录 原项目地址 第41课:SQL详解之DDL 建库建表 删除表和修改表 第42课:SQL详解之DML insert操作 delete 操作 update 操作 完整的数据 第43课:S ...

  5. 数据库SQL语言分类(DDL/DML/DQL/TCL/DCL)

    文章目录 一.数据定义语言 DDL (一)create 数据库对象的创建 (二)alter 修改数据库对象 (三)drop 删除数据库对象 (四)truncate 清空表数据 二.数据操纵语言 DML ...

  6. 【mysql篇】mysql数据库知识点(四种语言)

    mysql数据库语言分为四种DDL,DQL,DML,DCL下面我们一一介绍: 注:(上图取自黑马程序员的课程APP中,这些笔记也是看了黑马程序员的课程之后做的): 一,       DDL(data ...

  7. 76.数据库操纵语言DML 定义语言 DDL 控制语言DCL

    数据库操纵语言DML:用户通过它实现对数据库的基本操作(增删改查) 是在外模式里 数据库定义语言DDL:数据库设计人员通过它实现对数据库结构.操作方法等的定义 DDL比DML多,定义或改变表的结构.数 ...

  8. 关系型数据库语言分类(DDL,DML,DCL)

    关系数据库的语言分三类,它们是(数据描述语言DDL).(数据操纵语言DML)和(数据控制语言DCL),而SQL是(集DDL.DML.DCL为一体)的标准关系数据库语言. DDL is Data Def ...

  9. 计算机新手教程装系统,新手小白必看电脑重装系统教程 四种方法至少会一种就够用!...

    电脑买来时间久了,就会出来卡顿.蓝屏等很多问题.你的电脑有这些问题吗?当电脑出现这些问题时,我们该怎么做呢?当然就是给电脑重装系统,那么你会给电脑重装系统吗?小白必看的电脑重装系统教程哦! 给电脑装系 ...

最新文章

  1. SpringBoot基础入门
  2. Nginx 301跳转踩坑总结
  3. Pwn环境配置(三)——ubuntu环境搭建
  4. comparator比较器用法_汽车三元催化器堵塞咋办?不拆不换,用这招清理干净、动力猛如虎...
  5. 【推荐】 女人愁嫁时代终于来临
  6. 华为畅享max有没有人脸识别_华为三款5000mAh超大电池手机,都是续航王者,最低只要1499元...
  7. 计算机打开就是桌面界面的讲解,电脑桌面图标打不开,小猪教您电脑桌面图标打不开怎么办...
  8. JAVA的Random类(转)
  9. Redis 官方可视化工具,功能真强大
  10. dwg转换pdf怎么转换?
  11. 迁移学习Transfer Learning
  12. 赠书!Python 安全攻防,终于来了!
  13. Springboot毕设项目查听课管理系统zkb6w(java+VUE+Mybatis+Maven+Mysql)
  14. foo java_Java的类型参数通配符到底意味着什么? Foo和Foo ?之间的真正区别是什么?...
  15. Android开发系列7——icon图标和开机启动页
  16. 计算机二级的Word知识点,计算机二级word知识点「干货」
  17. 智能驾驶系统简介和测试要点分析
  18. 通用对话框——FolderBrowserDialog
  19. MySQL数据库-表的插入详解
  20. 输入精度e,使用格雷戈里公式求π的近似值,精确到最后一项的绝对值小于e。要求定义和调用函数funpi(e)求π的近似值。

热门文章

  1. python3.6安装包多大_win10下Python3.6安装、配置以及pip安装包教程
  2. 数据结构稀疏矩阵的加法十字链表_学习数据结构和算法的框架思维
  3. C语言中图形方式界面怎么,「分享」C语言如何编写图形界面
  4. linux中useradd的文件路径,linux的useradd命令详细解释
  5. POJ3522Slim Span(最大边与最小边差值最小的生成树)
  6. IPV6地址校验(java)
  7. 如何在高并下设置Linux系统及kernel参数
  8. JS中调用本地Winform程序并传递参数
  9. Vue+Openlayers实现地图缩放图标等比例缩放
  10. EasyUI中分页的简单使用