閱讀711 返回首頁    go 技術社區[雲棲]


數據庫必會必知 之 SQL四種語言:DDL DML DCL TCL

今天群裏麵討論,DDL 還是 DML,我這種小白還是總結下他們的區別吧。

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中處理數據庫中的數據

其主要命令有SELECT,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

休息下,一個例子不夠,再來一個。代碼都在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

 

最後來張圖總結:

QQ20160608-0@2x

轉載自 並發編程網 - ifeve.com

 

最後更新:2017-05-19 14:33:42

  上一篇:go  InterruptedException 和 interrupting threads 的一些說明
  下一篇:go  《Redis官方文檔》發布和訂閱