国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 13:10:08
字體:
供稿:網(wǎng)友

看到很多人討論SQL還分為四種類型,在這里知識普及一下,并總結(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)建對象

例:

CREATE DATABASE test; // 創(chuàng)建一個名為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ù)庫中刪除對象

例:

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

還有其他的:

TRUNCATE – 截斷表內(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)用一個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è)置保存點,可以回滾到此處

ROLLBACK – 回滾

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

例子:Java中JDBC封裝了對事務(wù)的支持。比如我們首先新建一個表: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ù)回滾第一個例子 -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ū)動      Class.forName(DRIVER);      // 數(shù)據(jù)庫連接      conn = DriverManager.getConnection(URL,USER,PWD);       // 關(guān)閉自動提交的事務(wù)機制      conn.setAutoCommit(false);      // 設(shè)置事務(wù)隔離級別 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ù)隔離級別為 SERIALIZABLE 底層調(diào)用的是TCL語言的SET TRANSACTION

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

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

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

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

/** * 描述:JDBC數(shù)據(jù)庫事務(wù)回滾,回滾到特定的保存點 * * 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ū)動      Class.forName(DRIVER);      // 數(shù)據(jù)庫連接      conn = DriverManager.getConnection(URL,USER,PWD);       // 關(guān)閉自動提交的事務(wù)機制      conn.setAutoCommit(false);      // 設(shè)置事務(wù)隔離級別 SERIALIZABLE      conn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);       Statement stmt = conn.createStatement();      int rows = stmt.executeUpdate("INSERT INTO city VALUES (3,'china',1,'cc')");      // 設(shè)置事務(wù)保存點      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();        }      }    }  }}

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

第 9 行:聲明了一個保存點

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

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

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

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

數(shù)據(jù)庫ddl,dml,dcl,sql,ddl,dql,mysql

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


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 梨树县| 兖州市| 永吉县| 宣威市| 民县| 民丰县| 福建省| 弥渡县| 抚顺县| 航空| 盐亭县| 新野县| 沈丘县| 高雄县| 永丰县| 延寿县| 濮阳县| 张掖市| 白山市| 福海县| 宜阳县| 皮山县| 阿克陶县| 翁源县| 寻乌县| 遂昌县| 虹口区| 土默特左旗| 丰都县| 达拉特旗| 资溪县| 报价| 运城市| 迁安市| 杨浦区| 积石山| 香格里拉县| 扬中市| 宜章县| 咸宁市| 洛宁县|