《Mysql入門詳解SQL四種語言:DDL DML DCL TCL》要點:
本文介紹了Mysql入門詳解SQL四種語言:DDL DML DCL TCL,希望對您有用。如果有疑問,可以聯系我們。
MYSQL教程看到很多人討論SQL還分為四種類型,在這里知識普及一下,并總結下他們的區別吧.
MYSQL教程1. DDL C Data Definition Language
MYSQL教程數據庫定義語言:定義數據庫的結構.
MYSQL教程其主要命令有CREATE,ALTER,DROP
等,下面用例子詳解.該語言不需要commit,因此慎重.
MYSQL教程CREATE C to create objects in the database?? 在數據庫創建對象
MYSQL教程例:
MYSQL教程
CREATE DATABASE test; // 創建一個名為test的數據庫
MYSQL教程ALTER C alters the structure of the database?? 修改數據庫結構
MYSQL教程例:
MYSQL教程
ALTER TABLE test ADD birthday date; // 修改test表,新增date類型的birthday列
MYSQL教程DROP C delete objects from the database?? 從數據庫中刪除對象
MYSQL教程例:
MYSQL教程
DROP DATABASE test;// 刪除test數據庫
MYSQL教程還有其他的:
MYSQL教程TRUNCATE
C 截斷表內容(開發期,還是挺常用的)
MYSQL教程COMMENT
C 為數據字典添加備注
MYSQL教程2. DML C Data Manipulation Language
MYSQL教程數據庫操作語言:SQL中處理數據庫中的數據
MYSQL教程其主要命令有INSERT,UPDATE,DELETE
等,這些例子大家常用就不一一介紹了.該語言需要commit.還有常用的 LOCK TABLE.
MYSQL教程還有其他不熟悉的:
MYSQL教程CALL
C 調用一個PL/SQL或Java子程序
MYSQL教程EXPLAIN PLAN
C 解析分析數據拜訪路徑
MYSQL教程3. DCL C Data Control Language
MYSQL教程數據庫控制語言:授權,角色控制等
MYSQL教程GRANT
C 為用戶賦予拜訪權限
MYSQL教程REVOKE
C 撤回授權權限
MYSQL教程4. TCL C Transaction Control Language
MYSQL教程事務控制語言
MYSQL教程COMMIT
C 保存已完成的工作
MYSQL教程SAVEPOINT
C 在事務中設置保存點,可以回滾到此處
MYSQL教程ROLLBACK
C 回滾
MYSQL教程SET TRANSACTION
C 改變事務選項
MYSQL教程例子:Java中JDBC封裝了對事務的支持.比如我們首先新建一個表:test
MYSQL教程test.sql
MYSQL教程
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;
MYSQL教程JDBC事務回滾第一個例子 -JDBC數據庫事務回滾:
MYSQL教程
/**
* 描述: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();
}
}
}
}
}
MYSQL教程第 19 行:設置了事務隔離級別為 SERIALIZABLE 底層調用的是TCL語言的SET TRANSACTION
MYSQL教程第 22 行:執行通過,插入數據
MYSQL教程第 23 行:執行不通過,沒有主鍵為4的記錄,直接拋出異常
MYSQL教程第 31 行:事務回滾,封裝的就是 TCL 語句的ROLLBACK
MYSQL教程JDBC事務回滾第二個例子-JDBC數據庫事務回滾,回滾到特定的保存點:
MYSQL教程
/**
* 描述: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();
}
}
}
}
}
MYSQL教程和第一個例子重復的就不提了.
MYSQL教程第 9 行:聲明了一個保存點
MYSQL教程第 24 行:設置了保存點
MYSQL教程第 33 行:回滾事務到該保存點
MYSQL教程上面的代碼涉及到的是 TCL語言中的 SAVEPOINT
MYSQL教程最后來張圖總結:(SELECT屬于DQL哈.)
MYSQL教程
MYSQL教程希望本文對大家學習sql有所贊助.
《Mysql入門詳解SQL四種語言:DDL DML DCL TCL》是否對您有啟發,歡迎查看更多與《Mysql入門詳解SQL四種語言:DDL DML DCL TCL》相關教程,學精學透。維易PHP學院為您提供精彩教程。