詳解SQL四種語言:DDL DML DCL TCL
看到很多人討論SQL還分為四種類型,在這里知識普及一下,并總結(jié)下他們的區(qū)別吧。
1. DDL – Data Definition Language
數(shù)據(jù)庫定義語言:定義數(shù)據(jù)庫的結(jié)構(gòu)。
其主要命令有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ù)庫結(jié)構(gòu)
例:
ALTER TABLE test ADD birthday date; // 修改test表,新增date類型的birthday列
DROP – delete objects from the database 從數(shù)據(jù)庫中刪除對象
例:
DROP DATABASE test;// 刪除test數(shù)據(jù)庫
還有其他的:
TRUNCATE – 截斷表內(nèi)容(開發(fā)期,還是挺常用的)
COMMENT – 為數(shù)據(jù)字典添加備注
2. DML – Data Manipulation Language
數(shù)據(jù)庫操作語言:SQL中處理數(shù)據(jù)庫中的數(shù)據(jù)
其主要命令有INSERT,UPDATE,DELETE等,這些例子大家常用就不一一介紹了。該語言需要commit。還有常用的 LOCK TABLE。
還有其他不熟悉的:
CALL – 調(diào)用一個PL/SQL或Java子程序
EXPLAIN PLAN – 解析分析數(shù)據(jù)訪問路徑
3. DCL – Data Control Language
數(shù)據(jù)庫控制語言:授權(quán),角色控制等
GRANT – 為用戶賦予訪問權(quán)限
REVOKE – 撤回授權(quán)權(quán)限
4. TCL – Transaction Control Language
事務(wù)控制語言
COMMIT – 保存已完成的工作
SAVEPOINT – 在事務(wù)中設(shè)置保存點,可以回滾到此處
ROLLBACK – 回滾
SET TRANSACTION – 改變事務(wù)選項
例子:Java中JDBC封裝了對事務(wù)的支持。比如我們首先新建一個表: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事務(wù)回滾第一個例子 -JDBC數(shù)據(jù)庫事務(wù)回滾:
/**
* 描述:JDBC數(shù)據(jù)庫事務(wù)回滾
*
* 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ù)庫驅(qū)動
Class.forName(DRIVER);
// 數(shù)據(jù)庫連接
conn = DriverManager.getConnection(URL,USER,PWD);
// 關(guān)閉自動提交的事務(wù)機制
conn.setAutoCommit(false);
// 設(shè)置事務(wù)隔離級別 SERIALIZABLE
conn.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");
// 提交事務(wù)
conn.commit();
} catch (Exception e) {
e.printStackTrace();
// 回滾事務(wù)
if (conn != null) {
conn.rollback();
}
} finally {
/** 關(guān)閉數(shù)據(jù)庫連接 */
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}
第 19 行:設(shè)置了事務(wù)隔離級別為 SERIALIZABLE 底層調(diào)用的是TCL語言的SET TRANSACTION
第 22 行:執(zhí)行通過,插入數(shù)據(jù)
第 23 行:執(zhí)行不通過,沒有主鍵為4的記錄,直接拋出異常
第 31 行:事務(wù)回滾,封裝的就是 TCL 語句的ROLLBACK
JDBC事務(wù)回滾第二個例子-JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點:
/**
* 描述:JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點
*
* 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ù)庫驅(qū)動
Class.forName(DRIVER);
// 數(shù)據(jù)庫連接
conn = DriverManager.getConnection(URL,USER,PWD);
// 關(guān)閉自動提交的事務(wù)機制
conn.setAutoCommit(false);
// 設(shè)置事務(wù)隔離級別 SERIALIZABLE
conn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);
Statement stmt = conn.createStatement();
int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')");
// 設(shè)置事務(wù)保存點
svpt = conn.setSavepoint();
rows = stmt.executeUpdate("UPDATE city set country = 'TAIWAN' WHERE id = 4");
// 提交事務(wù)
conn.commit();
} catch (Exception e) {
e.printStackTrace();
// 回滾事務(wù)
if (conn != null) {
conn.rollback(svpt);
}
} finally {
/** 關(guān)閉數(shù)據(jù)庫連接 */
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}
和第一個例子重復(fù)的就不提了。
第 9 行:聲明了一個保存點
第 24 行:設(shè)置了保存點
第 33 行:回滾事務(wù)到該保存點
上面的代碼涉及到的是 TCL語言中的 SAVEPOINT
最后來張圖總結(jié):(SELECT屬于DQL哈。)

希望本文對大家學(xué)習(xí)sql有所幫助。
相關(guān)文章
Mysql之EXPLAIN顯示using filesort介紹
EXPLAIN 是mysql解釋select查詢的一個關(guān)鍵字,可以很方便的用于調(diào)試2012-02-02
MySQL replace函數(shù)替換字符串語句的用法
MySQL replace函數(shù)我們經(jīng)常用到,下面就為您詳細(xì)介紹MySQL replace函數(shù)的用法,希望對您學(xué)習(xí)MySQL replace函數(shù)方面能有所啟迪。2010-12-12
MySQL中的log_bin_trust_function_creators系統(tǒng)變量
本文主要介紹了MySQL中的log_bin_trust_function_creators系統(tǒng)變量,log_bin_trust_function_creators是一個全局系統(tǒng)變量,下面就來介紹一下具體使用,感興趣的可以了解一下2024-09-09
MySQL中的insert-on-duplicate語句舉例詳解
這篇文章主要給大家介紹了關(guān)于MySQL中insert-on-duplicate語句的相關(guān)資料,文中通過圖文以及代碼示例將insert-on-duplicate的用法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-06-06
解決net start mysql--服務(wù)無法啟動 服務(wù)沒有報告任何錯誤問題
這篇文章主要介紹了解決net start mysql--服務(wù)無法啟動 服務(wù)沒有報告任何錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
MySql批量插入優(yōu)化Sql執(zhí)行效率實例詳解
這篇文章主要介紹了MySql批量插入優(yōu)化Sql執(zhí)行效率實例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
一步步教你在Navicat上如何停止正在運行的MYSQL語句
很多時候我們會提交一些耗時比較長的sql,可能出現(xiàn)mysql服務(wù)器內(nèi)存或者CPU暴增,引起報警,甚至影響其他業(yè)務(wù),下面這篇文章主要給大家介紹了關(guān)于在Navicat上如何停止正在運行的MYSQL語句的相關(guān)資料,需要的朋友可以參考下2023-03-03
Linux下MySql 1036 錯誤碼解決(1036: Table ''xxxx'' is read only)
我們在進行數(shù)據(jù)庫搬家的時候,經(jīng)常會遇到(1036: Table 'xxxx' is read only)的問題,字面意思很明確,就是數(shù)據(jù)庫只有讀權(quán)限,無寫權(quán)限,那么我們來分享下我的處理辦法2014-07-07

