首頁  >  文章  >  資料庫  >  詳解SQL四種語言:DDL DML DCL TCL_MySQL

詳解SQL四種語言:DDL DML DCL TCL_MySQL

WBOY
WBOY原創
2016-08-20 08:48:101548瀏覽

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn