看到很多人討論SQL還分為四種類型,在這里知識普及一下,并總結下他們的區別吧。
1. DDL – Data Definition Language
數據庫定義語言:定義數據庫的結構。
其主要命令有CREATE,ALTER,DROP
等,下面用例子詳解。該語言不需要commit,因此慎重。
CREATE – to create objects in the database 在數據庫創建對象
例:
1
|
CREATE DATABASE test; // 創建一個名為test的數據庫 |
ALTER – alters the structure of the database 修改數據庫結構
例:
1
|
ALTER TABLE test ADD birthday date ; // 修改test表,新增 date 類型的birthday列 |
DROP – delete objects from the database 從數據庫中刪除對象
例:
1
|
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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數據庫事務回滾:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
/** * 描述: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數據庫事務回滾,回滾到特定的保存點:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
/** * 描述: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有所幫助。