做者:泥瓦匠 今天羣裏面討論,DDL 仍是 DML,我這種小白仍是總結下他們的區別吧。java
數據庫定義語言:定義數據庫的結構。 其主要命令有CREATE,ALTER,DROP等,下面用例子詳解。該語言不須要commit,所以慎重。git
CREATE - to create objects in the database 在數據庫建立對象github
例: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 - 爲數據字典添加備註
數據庫操做語言:SQL中處理數據庫中的數據 其主要命令有INSERT,UPDATE,DELETE等,這些例子你們經常使用就不一一介紹了。該語言須要commit。sql
還有經常使用的 LOCK TABLE ,記得寫過鎖的博客 - 傳送門數據庫
還有其餘不熟悉的:socket
CALL - 調用一個PL/SQL或Java子程序spa
EXPLAIN PLAN - 解析分析數據訪問路徑 code
數據庫控制語言:受權,角色控制等component
GRANT - 爲用戶賦予訪問權限對象
REVOKE - 撤回受權權限
事務控制語言
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
休息下,一個例子不夠,再來一個。代碼都在 github主頁上。 https://github.com/JeffLi1993/jee-component-learning
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