数据库必会必知 之 SQL四种语言:DDL DML DCL TCL
今天群里面讨论,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相关推荐
- SQL四种语言:DDL,DML,DCL,TCL
1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...
- SQL 四大功能DDL/DML/DCL/TCL
SQL主要分成四部分: (1)数据定义.(SQL DDL)用于定义SQL模式.基本表.视图和索引的创建和撤消操作. (2)数据操纵.(SQL DML)数据操纵分成数据查询和数据更新两类.数据更新又分成 ...
- 数据库,结构化查询语言的四种语言
SQL四种语言:DDL,DML,DCL,TCL 1.DDL(Data Definition Language)数据库定义语言statements are used to define the data ...
- Python|SQL详解之DDL|DML|DQL|DCL|索引|视图、函数和过程|JSON类型|窗口函数|接入MySQL|清屏|正则表达式|executemany|语言基础50课:学习(14)
文章目录 系列目录 原项目地址 第41课:SQL详解之DDL 建库建表 删除表和修改表 第42课:SQL详解之DML insert操作 delete 操作 update 操作 完整的数据 第43课:S ...
- 数据库SQL语言分类(DDL/DML/DQL/TCL/DCL)
文章目录 一.数据定义语言 DDL (一)create 数据库对象的创建 (二)alter 修改数据库对象 (三)drop 删除数据库对象 (四)truncate 清空表数据 二.数据操纵语言 DML ...
- 【mysql篇】mysql数据库知识点(四种语言)
mysql数据库语言分为四种DDL,DQL,DML,DCL下面我们一一介绍: 注:(上图取自黑马程序员的课程APP中,这些笔记也是看了黑马程序员的课程之后做的): 一, DDL(data ...
- 76.数据库操纵语言DML 定义语言 DDL 控制语言DCL
数据库操纵语言DML:用户通过它实现对数据库的基本操作(增删改查) 是在外模式里 数据库定义语言DDL:数据库设计人员通过它实现对数据库结构.操作方法等的定义 DDL比DML多,定义或改变表的结构.数 ...
- 关系型数据库语言分类(DDL,DML,DCL)
关系数据库的语言分三类,它们是(数据描述语言DDL).(数据操纵语言DML)和(数据控制语言DCL),而SQL是(集DDL.DML.DCL为一体)的标准关系数据库语言. DDL is Data Def ...
- 计算机新手教程装系统,新手小白必看电脑重装系统教程 四种方法至少会一种就够用!...
电脑买来时间久了,就会出来卡顿.蓝屏等很多问题.你的电脑有这些问题吗?当电脑出现这些问题时,我们该怎么做呢?当然就是给电脑重装系统,那么你会给电脑重装系统吗?小白必看的电脑重装系统教程哦! 给电脑装系 ...
最新文章
- SpringBoot基础入门
- Nginx 301跳转踩坑总结
- Pwn环境配置(三)——ubuntu环境搭建
- comparator比较器用法_汽车三元催化器堵塞咋办?不拆不换,用这招清理干净、动力猛如虎...
- 【推荐】 女人愁嫁时代终于来临
- 华为畅享max有没有人脸识别_华为三款5000mAh超大电池手机,都是续航王者,最低只要1499元...
- 计算机打开就是桌面界面的讲解,电脑桌面图标打不开,小猪教您电脑桌面图标打不开怎么办...
- JAVA的Random类(转)
- Redis 官方可视化工具,功能真强大
- dwg转换pdf怎么转换?
- 迁移学习Transfer Learning
- 赠书!Python 安全攻防,终于来了!
- Springboot毕设项目查听课管理系统zkb6w(java+VUE+Mybatis+Maven+Mysql)
- foo java_Java的类型参数通配符到底意味着什么? Foo和Foo ?之间的真正区别是什么?...
- Android开发系列7——icon图标和开机启动页
- 计算机二级的Word知识点,计算机二级word知识点「干货」
- 智能驾驶系统简介和测试要点分析
- 通用对话框——FolderBrowserDialog
- MySQL数据库-表的插入详解
- 输入精度e,使用格雷戈里公式求π的近似值,精确到最后一项的绝对值小于e。要求定义和调用函数funpi(e)求π的近似值。
热门文章
- python3.6安装包多大_win10下Python3.6安装、配置以及pip安装包教程
- 数据结构稀疏矩阵的加法十字链表_学习数据结构和算法的框架思维
- C语言中图形方式界面怎么,「分享」C语言如何编写图形界面
- linux中useradd的文件路径,linux的useradd命令详细解释
- POJ3522Slim Span(最大边与最小边差值最小的生成树)
- IPV6地址校验(java)
- 如何在高并下设置Linux系统及kernel参数
- JS中调用本地Winform程序并传递参数
- Vue+Openlayers实现地图缩放图标等比例缩放
- EasyUI中分页的简单使用