詳解SQL四種說話:DDL DML DCL TCL。本站提示廣大學習愛好者:(詳解SQL四種說話:DDL DML DCL TCL)文章只能為提供參考,不一定能成為您想要的結果。以下是詳解SQL四種說話:DDL DML DCL TCL正文
看到許多人評論辯論SQL還分為四品種型,在這裡常識普及一下,並總結下他們的差別吧。
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中處置數據庫中的數據
其重要敕令有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); // 設置事務隔離級別 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"); // 提交事務 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
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); // 設置事務隔離級別 SERIALIZABLE conn.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
最初來張圖總結:(SELECT屬於DQL哈。)
願望本文對年夜家進修sql有所贊助。