程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 詳解SQL四種說話:DDL DML DCL TCL

詳解SQL四種說話:DDL DML DCL TCL

編輯:MySQL綜合教程

詳解SQL四種說話:DDL DML DCL TCL。本站提示廣大學習愛好者:(詳解SQL四種說話:DDL DML DCL TCL)文章只能為提供參考,不一定能成為您想要的結果。以下是詳解SQL四種說話:DDL DML DCL TCL正文


看到許多人評論辯論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有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved