一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - 詳解SQL四種語言:DDL DML DCL TCL

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

2020-06-17 17:03daisy Mysql

本文詳細介紹了sql的四種語言,包括數據定義語言(DDL)、數據操作語言(DML)、數據控制語言(DCL)和事物控制語言(TCL)。在這幾種語言中有疑惑的可以來看看這篇文章。

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

1. DDL – Data Definition Language

數據庫定義語言:定義數據庫的結構。

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

CREATE – to create objects in the database   在數據庫創建對象

例:

?
1
CREATE DATABASE test; // 創建一個名為test的數據庫

ALTER – alters the structure of the database   修改數據庫結構

例:

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

DROP – delete objects from the database   從數據庫中刪除對象

例:

?
1
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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數據庫事務回滾:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/**
 * 描述: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數據庫事務回滾,回滾到特定的保存點:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
 * 描述: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四種語言:DDL DML DCL TCL

希望本文對大家學習sql有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人精品免费网站 | 日本三级在线观看免费 | 国产在线观看91精品一区 | 国产在线成人精品 | 日本性生活大片 | 国产一卡2卡3卡四卡精品网站 | 国产永久免费视频m3u8 | 成年人在线免费观看视频网站 | 欧美一区二区三区久久久 | 亚洲欧美乱 | 亚洲天堂网站在线 | 男人天堂官方网站 | 91精品啪在线观看国产老湿机 | 久久视频在线视频观看精品15 | 视频亚洲一区 | 欧美人成绝费网站色www吃脚 | 边吃奶边扎下面 | 70岁多老妇人特黄a级毛片 | 亚洲欧美久久婷婷爱综合一区天堂 | 91精品国产91久久久久 | 99热导航| 能播放的欧美同性videos | 好大好热| 天天gan | 日本邪恶动态 | 美国videos| heyzo在线播放 | 国产经典一区二区三区蜜芽 | 亚洲国产精品久久久久久网站 | 扒开腚眼子视频大全 | 亚洲欧美优优色在线影院 | 高清视频在线播放ww | 国产自在自拍 | 猛男壮男受bl爽哭了高h | 无码骚夜夜精品 | 亚洲同性男男gay1069 | 国产麻豆网 | 午夜办公室在线观看高清电影 | 东北恋哥在线播放免费播放 | 91啦在线视频 | 青青青久热国产精品视频 |