亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2016年07月21日 16:29:30   投稿:daisy  
本文詳細(xì)介紹了sql的四種語言,包括數(shù)據(jù)定義語言(DDL)、數(shù)據(jù)操作語言(DML)、數(shù)據(jù)控制語言(DCL)和事物控制語言(TCL)。在這幾種語言中有疑惑的可以來看看這篇文章。

看到很多人討論SQL還分為四種類型,在這里知識(shí)普及一下,并總結(jié)下他們的區(qū)別吧。

1. DDL – Data Definition Language

數(shù)據(jù)庫定義語言:定義數(shù)據(jù)庫的結(jié)構(gòu)。

其主要命令有CREATE,ALTER,DROP等,下面用例子詳解。該語言不需要commit,因此慎重。

CREATE – to create objects in the database   在數(shù)據(jù)庫創(chuàng)建對(duì)象

例:

CREATE DATABASE test; // 創(chuàng)建一個(gè)名為test的數(shù)據(jù)庫

ALTER – alters the structure of the database   修改數(shù)據(jù)庫結(jié)構(gòu)

例:

ALTER TABLE test ADD birthday date; // 修改test表,新增date類型的birthday列

DROP – delete objects from the database   從數(shù)據(jù)庫中刪除對(duì)象

例:

DROP DATABASE test;// 刪除test數(shù)據(jù)庫

還有其他的:

TRUNCATE – 截?cái)啾韮?nèi)容(開發(fā)期,還是挺常用的)

COMMENT – 為數(shù)據(jù)字典添加備注

2. DML – Data Manipulation Language

數(shù)據(jù)庫操作語言:SQL中處理數(shù)據(jù)庫中的數(shù)據(jù)

其主要命令有INSERT,UPDATE,DELETE等,這些例子大家常用就不一一介紹了。該語言需要commit。還有常用的 LOCK TABLE。

還有其他不熟悉的:

CALL – 調(diào)用一個(gè)PL/SQL或Java子程序

EXPLAIN PLAN – 解析分析數(shù)據(jù)訪問路徑

3. DCL – Data Control Language

數(shù)據(jù)庫控制語言:授權(quán),角色控制等

GRANT – 為用戶賦予訪問權(quán)限

REVOKE – 撤回授權(quán)權(quán)限

4. TCL – Transaction Control Language

事務(wù)控制語言

COMMIT – 保存已完成的工作

SAVEPOINT – 在事務(wù)中設(shè)置保存點(diǎn),可以回滾到此處

ROLLBACK – 回滾

SET TRANSACTION – 改變事務(wù)選項(xiàng)

例子:Java中JDBC封裝了對(duì)事務(wù)的支持。比如我們首先新建一個(gè)表: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 '狀態(tài)',
 `country` varchar(20) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
 
SET FOREIGN_KEY_CHECKS = 1;

JDBC事務(wù)回滾第一個(gè)例子 -JDBC數(shù)據(jù)庫事務(wù)回滾:

/**
 * 描述:JDBC數(shù)據(jù)庫事務(wù)回滾
 *
 * Created by bysocket on 16/6/6.
 */
public class TransactionRollBack extends BaseJDBC {
 
  public static void main(String[] args) throws SQLException {
    Connection conn = null;
    try {
      // 加載數(shù)據(jù)庫驅(qū)動(dòng)
      Class.forName(DRIVER);
      // 數(shù)據(jù)庫連接
      conn = DriverManager.getConnection(URL,USER,PWD);
 
      // 關(guān)閉自動(dòng)提交的事務(wù)機(jī)制
      conn.setAutoCommit(false);
      // 設(shè)置事務(wù)隔離級(jí)別 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");
 
      // 提交事務(wù)
      conn.commit();
    } catch (Exception e) {
      e.printStackTrace();
      // 回滾事務(wù)
      if (conn != null) {
        conn.rollback();
      }
    } finally {
      /** 關(guān)閉數(shù)據(jù)庫連接 */
      if (conn != null) {
        try {
          conn.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
      }
    }
  }
}

第 19 行:設(shè)置了事務(wù)隔離級(jí)別為 SERIALIZABLE 底層調(diào)用的是TCL語言的SET TRANSACTION

第 22 行:執(zhí)行通過,插入數(shù)據(jù)

第 23 行:執(zhí)行不通過,沒有主鍵為4的記錄,直接拋出異常

第 31 行:事務(wù)回滾,封裝的就是 TCL 語句的ROLLBACK

JDBC事務(wù)回滾第二個(gè)例子-JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點(diǎn):

/**
 * 描述:JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點(diǎn)
 *
 * 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 {
      // 加載數(shù)據(jù)庫驅(qū)動(dòng)
      Class.forName(DRIVER);
      // 數(shù)據(jù)庫連接
      conn = DriverManager.getConnection(URL,USER,PWD);
 
      // 關(guān)閉自動(dòng)提交的事務(wù)機(jī)制
      conn.setAutoCommit(false);
      // 設(shè)置事務(wù)隔離級(jí)別 SERIALIZABLE
      conn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);
 
      Statement stmt = conn.createStatement();
      int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')");
      // 設(shè)置事務(wù)保存點(diǎn)
      svpt = conn.setSavepoint();
      rows = stmt.executeUpdate("UPDATE city set country = 'TAIWAN' WHERE id = 4");
 
      // 提交事務(wù)
      conn.commit();
    } catch (Exception e) {
      e.printStackTrace();
      // 回滾事務(wù)
      if (conn != null) {
        conn.rollback(svpt);
      }
    } finally {
      /** 關(guān)閉數(shù)據(jù)庫連接 */
      if (conn != null) {
        try {
          conn.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
      }
    }
  }
}

和第一個(gè)例子重復(fù)的就不提了。

第 9 行:聲明了一個(gè)保存點(diǎn)

第 24 行:設(shè)置了保存點(diǎn)

第 33 行:回滾事務(wù)到該保存點(diǎn)

上面的代碼涉及到的是 TCL語言中的 SAVEPOINT

最后來張圖總結(jié):(SELECT屬于DQL哈。)

希望本文對(duì)大家學(xué)習(xí)sql有所幫助。

相關(guān)文章

  • Mysql 如何查詢時(shí)間段交集

    Mysql 如何查詢時(shí)間段交集

    這篇文章主要介紹了Mysql 查詢時(shí)間段交集的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • DOS命令行窗口mysql中文顯示亂碼問題解決方法

    DOS命令行窗口mysql中文顯示亂碼問題解決方法

    MySQL的默認(rèn)編碼是Latin1,不支持中文,如何修改MySQL的默認(rèn)編碼呢,下面為大家詳細(xì)介紹下
    2014-05-05
  • mysql增量備份與恢復(fù)使用詳解

    mysql增量備份與恢復(fù)使用詳解

    對(duì)線上運(yùn)行的mysql數(shù)據(jù)庫來說,周期性做數(shù)據(jù)庫備份具有重要的意義,一方面可以防止數(shù)據(jù)丟失,另一方面,備份的數(shù)據(jù)可以快速在不同的環(huán)境中使用、遷移,本文將給大家詳細(xì)介紹mysql增量備份與恢復(fù)使用,需要的朋友可以參考下
    2023-09-09
  • mysql時(shí)區(qū)查看與設(shè)置方法

    mysql時(shí)區(qū)查看與設(shè)置方法

    這篇文章主要介紹了mysql時(shí)區(qū)查看與設(shè)置方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQL截取和拆分字符串函數(shù)用法示例

    MySQL截取和拆分字符串函數(shù)用法示例

    這篇文章主要介紹了MySQL截取和拆分字符串函數(shù)用法,結(jié)合實(shí)例形式分析了mysql針對(duì)字符串的截取與拆分函數(shù)SUBSTRING及SUBSTRING_INDEX相關(guān)使用方法,需要的朋友可以參考下
    2016-09-09
  • 解決MySQL8.0 輸入無誤仍然提示Access denied問題

    解決MySQL8.0 輸入無誤仍然提示Access denied問題

    這篇文章主要介紹了解決MySQL8.0 輸入無誤仍然提示Access denied問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • mysql查看表結(jié)構(gòu)的三種方法總結(jié)

    mysql查看表結(jié)構(gòu)的三種方法總結(jié)

    這篇文章主要介紹了mysql查看表結(jié)構(gòu)的三種方法總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 一條SQL更新語句的執(zhí)行過程解析

    一條SQL更新語句的執(zhí)行過程解析

    這篇文章主要介紹了一條SQL更新語句的執(zhí)行過程解析,所以一條更新語句的執(zhí)行流程又是怎樣的呢?下面我們一起進(jìn)入文章了解更多具體內(nèi)容吧
    2022-05-05
  • gearman + mysql方式實(shí)現(xiàn)持久化操作示例

    gearman + mysql方式實(shí)現(xiàn)持久化操作示例

    這篇文章主要介紹了gearman + mysql方式實(shí)現(xiàn)持久化操作,簡(jiǎn)單描述了持久化的概念、原理,并結(jié)合實(shí)例形式分析了gearman + mysql持久化操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2020-02-02
  • MySQL8.0.23安裝超詳細(xì)教程

    MySQL8.0.23安裝超詳細(xì)教程

    這篇文章主要介紹了MySQL8.0.23安裝超詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01

最新評(píng)論