MySQL語(yǔ)句整理及匯總介紹
SQL(Structured Query Language)語(yǔ)句,即結(jié)構(gòu)化查詢語(yǔ)言,是操作和檢索關(guān)系數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn)語(yǔ)言。SQL語(yǔ)句一般分為以下幾種:
- DCL(Database Control Language,數(shù)據(jù)控制語(yǔ)言)語(yǔ)句:主要由GRANT和REVOKE兩個(gè)關(guān)鍵字完成
- DDL(Database Definition Language,數(shù)據(jù)定義語(yǔ)言)語(yǔ)句:主要由CREATE、ALTER、DROP和TRUNCATE四個(gè)關(guān)鍵字完成
- DML(Database Manipulation Language,數(shù)據(jù)操作語(yǔ)言)語(yǔ)句:主要由INSERT、UPDATE和DELETE三個(gè)關(guān)鍵字完成
- 查詢語(yǔ)句:主要由SELECT語(yǔ)句完成
- 事務(wù)控制語(yǔ)句:主要由COMMIT、ROLLBACK和SAVEPOINT三個(gè)關(guān)鍵字完成
注:SQL語(yǔ)句不區(qū)分大小寫,所以create和CREATE是相同的
一.DCL語(yǔ)句
DCL語(yǔ)句就是對(duì)用戶進(jìn)行授權(quán)和授權(quán)收回的操作,可以對(duì)不同的用戶的權(quán)限進(jìn)行控制,增加數(shù)據(jù)庫(kù)安全性,進(jìn)行數(shù)據(jù)庫(kù)的維護(hù)。一般都是數(shù)據(jù)庫(kù)管理員使用超級(jí)用戶root進(jìn)行操作。
MySQL的權(quán)限命令是grant,權(quán)限撤銷的命令時(shí)revoke;
1.grant授權(quán)格式:
grant 權(quán)限列表 on 庫(kù).表 to 用戶名@'ip' identified by "密碼";
2.revoke回收權(quán)限格式:
revoke 權(quán)限列表 on 庫(kù).表 from 用戶名@'ip';
二.DDL語(yǔ)句
數(shù)據(jù)庫(kù)對(duì)象:
表(table)、數(shù)據(jù)字典、約束(constraint)、視圖(view)、索引(index)、函數(shù)(function)、存儲(chǔ)過程(procedure)、觸發(fā)器(trigger)
CREATE、ALTER、DELETE關(guān)鍵字分別是創(chuàng)建、修改和刪除數(shù)據(jù)庫(kù)對(duì)象的,此處使用我們使用最多的對(duì)表的操作來(lái)舉例
- 數(shù)據(jù)庫(kù)的數(shù)據(jù)類型可參考://www.dbjr.com.cn/article/55853.htm
- 數(shù)據(jù)庫(kù)的完整性約束可參考:http://www.dbjr.com.cn/article/154000.htm
1.CREATE:
CREATE TABLE [模式名.] 表名(
該表中的列定義
);
e.g.
CREATE TABLE test( StuId VARCHAR(8) PRIMARY KEY, StuName VARCHAR(30) NOT NULL, StuAge SMALLINT NOT NULL, StuBirth DATETIME );
注:查看表結(jié)構(gòu):DESCRIBE 表名;
2.ALTER:
1)添加列:
ALTER TABLE 表名
ADD column columnName1 datatype [default expr] [FIRST|AFTER colName];
columnName1:新添加的列名;
datatype:數(shù)據(jù)類型;
default expr:完整性約束;
FIRST|AFTER colName:插入位置,默認(rèn)是插入在最后一列,F(xiàn)IRST是在第一列,AFTER colName是在指定列后插入
e.g.
ALTER TABLE test ADD column StuMajor VARCHAR(20) NOT NULL AFTER StuName;
2)修改列
ALTER TABLE 表名 CHANGE oldName newName datatype;
e.g.
ALTER TABLE test CHANGE StuBirth Birthday year;
3)刪除列
ALTER TABLE 表名 DROP column columnName;
e.g.
ALTER TABLE test DROP column StuMajor;
4)修改表名
ALTER TABEL 表名 RENAME TO 新表名;
e.g.
ALTER TABLE test RENAME TO student;
3.DROP
刪除表
DROP TABLE 表名;
e.g.
DROP TABLE student;
4.TRUNCATE
刪除表內(nèi)所有數(shù)據(jù)但保留表的結(jié)構(gòu),叫做“截?cái)唷?br /> TRUNCATE TABLE 表名;
e.g.
TRUNCATE TABLE student;
三.DML語(yǔ)句
1.INSERT
標(biāo)準(zhǔn)SQL語(yǔ)句只允許一次插入一條數(shù)據(jù),但MySQL對(duì)其進(jìn)行擴(kuò)展使其可以一次插入多條數(shù)據(jù)
插入一條數(shù)據(jù):
INSERT INTO 表名 VALUES(value1, value2, ...);
插入多條數(shù)據(jù):
INSERT INTO 表名 VALUES(value1,value2,...),(value1,value2,...),(value1,value2,...);
e.g.
INSERT INTO student VALUES(‘001','Lisa',20,1997),(‘002','Rose',21,1996);
2.UPDATE
UPDATE 表名 SET COLUMN1 = VALUE1[, COLUMN2 = VALUE2]...
[WHERE CONDITION];
e.g.將所有年齡大于20歲的學(xué)生的年齡+1
UPDATE student SET StuAge = StuAge+1 WHERE StuAge>20;
3.DELETE
DELETE FROM 表名 [WHERE CONDITION];
e.g.將所有1997年出生的學(xué)生信息刪除
DELETE FROM student WHERE Birthday = 1997;
四.查詢語(yǔ)句
1.單表查詢:
SELECT COLUMN1, COLUMN2... FROM 數(shù)據(jù)源 [WHERE CONDITION] [GROUP BY columnName] [ORDER BY columnName DESC|ASC]
e.g.將計(jì)算機(jī)科學(xué)專業(yè)的學(xué)生選出來(lái)并按照學(xué)號(hào)降序排列,只顯示學(xué)生姓名
SELECT StuName FROM student WHERE StuMajor = 'CS' ORDER BY StuId DESC;
2.多表查詢:
1)簡(jiǎn)單的外連接方式
SELECT VALUE1[,VALUE2]... FROM tableName1,tableName2 WHERE tableName1.column1 = tableName2.column2[AND ...]; WHERE 后跟的是連接條件和查詢條件
2)自連接:有時(shí)需要自己和自己進(jìn)行連接,叫做自連接
e.g.
有如下的表temp
CREATE TABLE emp( id INT AUTO_INCRETMENT PRIMARY KEY, name VARCAHR(255), mangerId INT, FOREIGN KEY(managerId) references temp(id) );
其中有四條記錄
id name managerId
1 aaa null
2 bbb 1
3 ccc 1
4 ddd 1
對(duì)該表進(jìn)行查詢操作:
SELECT employee.id, employee.name 員工名, manager.name 經(jīng)理名 FROM emp employee, emp manager WHERE employee.managerId = manager.id;
該查詢語(yǔ)句使用自連接顯示員工和經(jīng)理的關(guān)系,其中:
- employee.name 員工名, manager.name 經(jīng)理名 員工名和經(jīng)理名是重命名,在顯示列時(shí)顯示員工名和經(jīng)理名;
- FROM emp employee, emp manager 兩個(gè)相同的表需要進(jìn)行區(qū)分,起不同的名字;
- WHERE employee.managerId = manager.id 是連接條件
更多的多表連接可以參考:
http://www.dbjr.com.cn/article/154006.htm
五.事務(wù)處理
1.事務(wù)是由一步或幾步數(shù)據(jù)庫(kù)操作序列組成的邏輯執(zhí)行單元。
這系列操作要么全部執(zhí)行,要么全部放棄執(zhí)行。程序和事務(wù)是完全兩種不同的概念。一般而言,一段程序中可能包含多個(gè)事務(wù)。在MySQL中,有多種引擎,最常用的兩個(gè)引擎:InnoDB和MyISAM,其中InnoDB是支持事務(wù)的,而MyISAM是不支持的,可以在config配置文件中對(duì)其進(jìn)行修改。
2.事務(wù)的四個(gè)特性:
- 原子性(Atomicity):事務(wù)是應(yīng)用中最小的執(zhí)行單位。
- 一致性(Consistency):事務(wù)執(zhí)行的結(jié)果必須讓數(shù)據(jù)庫(kù)從一個(gè)一致性的狀態(tài)變成另外一個(gè)一致性的狀態(tài)。一致性是通過原子性保證的
- 隔離性(Isolation):各個(gè)事務(wù)執(zhí)行相互不干擾。
- 持續(xù)性(Durability):也成為持久性(Persistence),指事務(wù)一旦提交,將數(shù)據(jù)做的任何改變都保存進(jìn)物理數(shù)據(jù)庫(kù)。
這四個(gè)特性也叫ACID性
3.數(shù)據(jù)庫(kù)的事務(wù)由一組DML語(yǔ)句、一條DDL語(yǔ)句和一條DCL語(yǔ)句組成
- DML語(yǔ)句對(duì)數(shù)據(jù)進(jìn)行操作
- DDL和DCL都各只有一條,因?yàn)镈DL和DCL語(yǔ)句都會(huì)將事務(wù)提交
4.事務(wù)的提交:
- 顯示提交:commit
- 自動(dòng)提交:DDL/DCL語(yǔ)句
MySQL默認(rèn)關(guān)閉事務(wù)(自動(dòng)提交),在默認(rèn)情況下,用戶輸入一條DML語(yǔ)句也會(huì)提交該操作,為了開啟事務(wù)可以通過以下語(yǔ)句對(duì)自動(dòng)提交進(jìn)行設(shè)置
SET AUTOCOMMIT = {0|1} 0是關(guān)閉自動(dòng)提交(開啟事務(wù)),1是開啟自動(dòng)提交(關(guān)閉事務(wù))
5.事務(wù)的回滾(rollback)
事務(wù)包含的任意一個(gè)數(shù)據(jù)庫(kù)操作執(zhí)行失敗后執(zhí)行回滾事務(wù),將該事務(wù)中進(jìn)行的操作全部失效。兩種方式:
- 顯示回滾:rollback
- 自動(dòng)回滾:系統(tǒng)錯(cuò)誤或強(qiáng)行退出
6.例子:
若只是臨時(shí)開啟一個(gè)事務(wù)可以通過:start transaction或begin開啟臨時(shí)事務(wù),在其之后的DML語(yǔ)句都不會(huì)立即執(zhí)行,直到出現(xiàn)事務(wù)的提交或回滾才結(jié)束事務(wù)。
e.g.1
BEGIN; INSERT INTO student VALUES(NULL,'001','aaa'); INSERT INTO student VALUES(NULL,'002','bbb'); INSERT INTO student VALUES(NULL,'003','ccc'); SELECT * FROM student; ① ROLLBACK; SELECT * FROM student; ②
①語(yǔ)句查詢的結(jié)果中包含插入的數(shù)據(jù),但如果此時(shí)在別的命令行窗口中執(zhí)行該語(yǔ)句,也不會(huì)看到以上的三條數(shù)據(jù),體現(xiàn)了事務(wù)的隔離性,這三條數(shù)據(jù)其實(shí)并沒有寫入物理數(shù)據(jù)庫(kù);
在執(zhí)行了回滾操作后,在②的查詢語(yǔ)句的結(jié)果中看不到begin之后的那三條數(shù)據(jù)
e.g.2
INSERT INTO student VALUES(NULL,'001','aaa'); INSERT INTO student VALUES(NULL,'002','bbb'); SAVEPOINT p; INSERT INTO student VALUES(NULL,'003','ccc'); SELECT * FROM student; ① ROLLBACK TO p; SELECT * FROM student; ②
MySQL還提供關(guān)鍵字SAVEPOINT設(shè)置中間點(diǎn),可以設(shè)置回滾的位置,①處的查詢語(yǔ)句結(jié)果中包含三條插入數(shù)據(jù)的結(jié)果,但②處的查詢結(jié)果中不包含中間點(diǎn)p之后插入的數(shù)據(jù)。需要注意的是,回到中間點(diǎn)的回滾不會(huì)結(jié)束事務(wù)。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
mysql 從一個(gè)表中查數(shù)據(jù)并插入另一個(gè)表實(shí)現(xiàn)方法
這篇文章主要介紹了mysql 從一個(gè)表中查數(shù)據(jù)并插入另一個(gè)表實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2017-05-05mysql正確刪除數(shù)據(jù)的方法(drop,delete,truncate)
這篇文章主要給大家介紹了關(guān)于mysql正確刪除數(shù)據(jù)的相關(guān)資料,DELETE語(yǔ)句是MySQL中最常用的刪除數(shù)據(jù)的方式之一,但也有幾種其他方法來(lái)實(shí)現(xiàn),需要的朋友可以參考下2023-10-10MySQL-MMM安裝指南(Multi-Master Replication Manager for MySQL)
這篇文章主要介紹了mysql Multi-Master Replication Manager for MySQL的安裝方法,需要的朋友可以參考下2014-02-02MySQL實(shí)現(xiàn)replace函數(shù)的幾種實(shí)用場(chǎng)景
這篇文章主要介紹了MySQL實(shí)現(xiàn)replace函數(shù)的幾種實(shí)用場(chǎng)景,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02MySQL數(shù)據(jù)庫(kù)手冊(cè)DATABASE操作與編碼(小白入門篇)
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)手冊(cè)DATABASE操作與編碼的小白入門篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05The MySQL server is running with the --read-only option so i
1209 - The MySQL server is running with the --read-only option so it cannot execute this statement2020-08-08MySQL性能優(yōu)化的一些技巧幫助你的數(shù)據(jù)庫(kù)
你完成了你的品牌新的應(yīng)用程序,一切工作就像一個(gè)魅力;突然間,一個(gè)大爆發(fā)的用戶你的MySQL服務(wù)器,您的網(wǎng)站已關(guān)閉,是什么問題導(dǎo)致的呢?以下是MySQL性能優(yōu)化的一些技巧,將幫助你,幫助你的數(shù)據(jù)庫(kù)2013-01-01