看到很多人討論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有幫助。