日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

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

發(fā)布時間:2025/3/19 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据库必会必知 之 SQL四种语言:DDL DML DCL TCL 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

今天群里面討論,DDL 還是 DML,我這種小白還是總結下他們的區(qū)別吧。

1. DDL – Data Definition Language

數(shù)據(jù)庫定義語言:定義數(shù)據(jù)庫的結構。

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

CREATE – to create objects in the database ? 在數(shù)據(jù)庫創(chuàng)建對象

例:CREATE DATABASE test; // 創(chuàng)建一個名為test的數(shù)據(jù)庫

ALTER – alters the structure of the database?? 修改數(shù)據(jù)庫結構

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

DROP – delete objects from the database ? 從數(shù)據(jù)庫中刪除對象

例:DROP DATABASE test;// 刪除test數(shù)據(jù)庫

還有其他的:

TRUNCATE –?截斷表內容(開發(fā)期,還是挺常用的)

COMMENT –?為數(shù)據(jù)字典添加備注

?

2. DML – Data Manipulation Language

數(shù)據(jù)庫操作語言:SQL中處理數(shù)據(jù)庫中的數(shù)據(jù)

其主要命令有SELECT,INSERT,UPDATE,DELETE等,這些例子大家常用就不一一介紹了。該語言需要commit。還有常用的 LOCK TABLE ,記得寫過鎖的博客 –?傳送門

還有其他不熟悉的:

CALL – 調用一個PL/SQL或Java子程序
EXPLAIN PLAN – 解析分析數(shù)據(jù)訪問路徑

?

3.?DCL – Data Control Language

數(shù)據(jù)庫控制語言:授權,角色控制等

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 '狀態(tài)',`country` varchar(20) DEFAULT NULL,PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=latin1;SET FOREIGN_KEY_CHECKS = 1;

JDBC事務回滾第一個例子 -JDBC數(shù)據(jù)庫事務回滾:

/*** 描述:JDBC數(shù)據(jù)庫事務回滾** Created by bysocket on 16/6/6.*/ public class TransactionRollBack extends BaseJDBC {public static void main(String[] args) throws SQLException {Connection conn = null;try {// 加載數(shù)據(jù)庫驅動Class.forName(DRIVER);// 數(shù)據(jù)庫連接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 {/** 關閉數(shù)據(jù)庫連接 */if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}} }

第 19 行:設置了事務隔離級別為?SERIALIZABLE 底層調用的是TCL語言的SET TRANSACTION

第 22 行:執(zhí)行通過,插入數(shù)據(jù)

第 23 行:執(zhí)行不通過,沒有主鍵為4的記錄,直接拋出異常

第 31 行:事務回滾,封裝的就是 TCL 語句的ROLLBACK

休息下,一個例子不夠,再來一個。代碼都在github主頁上。https://github.com/JeffLi1993/jee-component-learning

JDBC事務回滾第二個例子-JDBC數(shù)據(jù)庫事務回滾,回滾到特定的保存點:

/*** 描述:JDBC數(shù)據(jù)庫事務回滾,回滾到特定的保存點** 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 {// 加載數(shù)據(jù)庫驅動Class.forName(DRIVER);// 數(shù)據(jù)庫連接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 {/** 關閉數(shù)據(jù)庫連接 */if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}} }

和第一個例子重復的就不提了。

第 9 行:聲明了一個保存點

第 24 行:設置了保存點

第 33 行:回滾事務到該保存點

上面的代碼涉及到的是 TCL語言中的?SAVEPOINT

?

最后來張圖總結:

轉載自?并發(fā)編程網 - ifeve.com

?

總結

以上是生活随笔為你收集整理的数据库必会必知 之 SQL四种语言:DDL DML DCL TCL的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。