詳解SQL四種語言:DDL DML DCL TCL
看到很多人討論SQL還分為四種類型,在這里知識(shí)普及一下,并總結(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)建對(duì)象
例:
CREATE DATABASE test; // 創(chuàng)建一個(gè)名為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ù)庫中刪除對(duì)象
例:
DROP DATABASE test;// 刪除test數(shù)據(jù)庫
還有其他的:
TRUNCATE
– 截?cái)啾韮?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)用一個(gè)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è)置保存點(diǎn),可以回滾到此處
ROLLBACK
– 回滾
SET TRANSACTION
– 改變事務(wù)選項(xiàng)
例子:Java中JDBC封裝了對(duì)事務(wù)的支持。比如我們首先新建一個(gè)表: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ù)回滾第一個(gè)例子 -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ū)動(dòng) Class.forName(DRIVER); // 數(shù)據(jù)庫連接 conn = DriverManager.getConnection(URL,USER,PWD); // 關(guān)閉自動(dòng)提交的事務(wù)機(jī)制 conn.setAutoCommit(false); // 設(shè)置事務(wù)隔離級(jí)別 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ù)隔離級(jí)別為 SERIALIZABLE 底層調(diào)用的是TCL語言的SET TRANSACTION
第 22 行:執(zhí)行通過,插入數(shù)據(jù)
第 23 行:執(zhí)行不通過,沒有主鍵為4的記錄,直接拋出異常
第 31 行:事務(wù)回滾,封裝的就是 TCL 語句的ROLLBACK
JDBC事務(wù)回滾第二個(gè)例子-JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點(diǎn):
/** * 描述:JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點(diǎn) * * 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ū)動(dòng) Class.forName(DRIVER); // 數(shù)據(jù)庫連接 conn = DriverManager.getConnection(URL,USER,PWD); // 關(guān)閉自動(dòng)提交的事務(wù)機(jī)制 conn.setAutoCommit(false); // 設(shè)置事務(wù)隔離級(jí)別 SERIALIZABLE conn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE); Statement stmt = conn.createStatement(); int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')"); // 設(shè)置事務(wù)保存點(diǎn) 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(); } } } } }
和第一個(gè)例子重復(fù)的就不提了。
第 9 行:聲明了一個(gè)保存點(diǎn)
第 24 行:設(shè)置了保存點(diǎn)
第 33 行:回滾事務(wù)到該保存點(diǎn)
上面的代碼涉及到的是 TCL語言中的 SAVEPOINT
最后來張圖總結(jié):(SELECT屬于DQL哈。)
希望本文對(duì)大家學(xué)習(xí)sql有所幫助。
相關(guān)文章
解決MySQL8.0 輸入無誤仍然提示Access denied問題
這篇文章主要介紹了解決MySQL8.0 輸入無誤仍然提示Access denied問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05mysql查看表結(jié)構(gòu)的三種方法總結(jié)
這篇文章主要介紹了mysql查看表結(jié)構(gòu)的三種方法總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07gearman + mysql方式實(shí)現(xiàn)持久化操作示例
這篇文章主要介紹了gearman + mysql方式實(shí)現(xiàn)持久化操作,簡(jiǎn)單描述了持久化的概念、原理,并結(jié)合實(shí)例形式分析了gearman + mysql持久化操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-02-02