濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL DML語句整理匯總

MySQL DML語句整理匯總

熱門標(biāo)簽:徐涇鎮(zhèn)騰訊地圖標(biāo)注 天津公司外呼系統(tǒng)軟件 自己做地圖標(biāo)注需要些什么 400電話申請廠家現(xiàn)貨 中國地圖標(biāo)注公司 百度地圖標(biāo)注要什么軟件 福建外呼電銷機器人加盟 電話機器人的價格多少錢一個月 昌德訊外呼系統(tǒng)

DML操作是指對數(shù)據(jù)庫中表記錄的操作,主要包括表記錄的插入(insert)、更新(update)、刪除(delete)和查詢(select),是開發(fā)人員日常使用最頻繁的操作。

1.插入(insert)

格式1.

INSERT INTO emp(ename,hiredate,sal,deptno) VALUES('zzx1','2000-01-01','2000',1);

格式2.

INSERT INTO emp VALUES('lisa','2003-02-01','3000',2);

不用指定字段名稱,但是value值需與表字段嚴(yán)格對應(yīng).

格式3.

INSERT INTO emp(ename,sal) VALUES('dony',1000);

對于含可空字段、非空但是含有默認(rèn)值的字段、自增字段,可以不用在INSERT后的字段列表里面出現(xiàn),VALUES后面只寫對應(yīng)字段名稱的VALUE:

格式4

在MySQL中,INSERT語句還可以一次性插入多條記錄:

INSERT INTO tablename(field1,field2,......fieldn)
VALUES
(record1_value1,record1_value2,......record1_valuen),
(record2_value1,record2_value2,......record2_valuen),
......
(recordn_value1,recordn_value2,......recordn_valuen);

2.更新(update)

格式1

UPDATE emp SET sal=4000 WHERE ename='lisa';

格式2

UPDATE t1,t2,...tn SET 
t1.field1=expr1,
t2.field2=expr2,
...
tn.fieldn=exprn [WHERE CONDITION];

同時更新多個表中的數(shù)據(jù)

3.刪除(delete)

格式1

DELETE FROM tablename [WHERE CONDITION];

格式2

DELETE t1,t2,...tn FROM t1,t2,...tn [WHERE CONDITION];

注意:不管是單表還是多表,不加where條件將會把表的所有記錄刪除,所以操作時一定要小心。

4.查詢(select)

基本語法:

SELECT * FROM tablename [WHERE CONDITION];

1.查詢不重復(fù)的記錄,可以用distinct關(guān)鍵字實現(xiàn):

SELECT DISTINCT deptno FROM emp;

2.條件查詢:

SELECT * FROM emp WHERE deptno=1;

其中,where 后面的條件除“=” 外,還可以使用 >、、>=、=、!=等比較運算符;

多個條件之間還可以使用or、and等邏輯運算符進(jìn)行多條件聯(lián)合查詢

3.排序和限制:

SELECT * FROM tablename [WHERE CONDITION] [ORDER BY field1 [DESC|ASC], field2 [DESC|ASC],...fieldn [DESC|ASC]];

其中,DESC和ASC是排序關(guān)鍵字,
DESC表示按照字段進(jìn)行降序排列(上大-下?。?br /> ASC則表示升序排列(上小-下大),
如果不寫此關(guān)鍵字默認(rèn)是升序排列。
ORDER BY 后面可以跟多個不同的排列字段,并且每個排序字段可以有不同的排序順序。

如果排序字段的值一樣,則值相同的字段按照第二個排序字段進(jìn)行排序,以此類推。如果只有一個排序字段,則這字段相同的記錄將會無序排列。

SELECT ......[LIMIT offset_start,row_count];

對于排序后的記錄,如果希望只顯示一部分,而不是全部,這時,就可以使用LIMIT關(guān)鍵字來實現(xiàn).

LIMIT 經(jīng)常和ORDER BY一起配合使用來進(jìn)行記錄的分頁顯示。

注意:limit屬于MySQL擴展SQL92后的語法,在其他數(shù)據(jù)庫上并不能通用。

4.聚合

很多情況下,我們需要進(jìn)行一些匯總操作,比如統(tǒng)計整個公司的人數(shù)或者統(tǒng)計每個部門的人數(shù),這是就要用到SQL的集合操作。

SELECT [field1,field2,......fieldn] fun_name
FROM tablename
[WHERE where_contition]
[GROUP BY field1,field2,......fieldn
[WITH ROLLUP]]
[HAVING where_contition];

對其參數(shù)進(jìn)行以下說明:

  1. fun_name 表示要做的集合操作,也就是聚合函數(shù),常用的有sum(求和)、count(*)(記錄數(shù))、max(最大值)、min(最小值)。
  2. GROUP BY 關(guān)鍵字表示要進(jìn)行分類聚合的字段,比如要按照部門分類統(tǒng)計員工數(shù)量,部門就應(yīng)該寫在group by后面。
  3. WITH ROLLUP 是可選語法,表明是否對分類聚合后的結(jié)果進(jìn)行再匯總。
  4. HAVING 關(guān)鍵字表示對分類后的結(jié)果再進(jìn)行條件的過濾。

注意:having和where的區(qū)別在于having是對聚合后的結(jié)果進(jìn)行條件的過濾,而where是在聚合前就對記錄進(jìn)行過濾,如果邏輯允許,我們盡可能用where先過濾記錄,這樣因為結(jié)果集減小,將對聚合的效率大大提高,最后再根據(jù)邏輯看是否用having進(jìn)行再過濾。

5.表連接

表連接分為內(nèi)連接和外連接,它們之間的最主要區(qū)別是:
內(nèi)連接僅選出兩張表中互相匹配的記錄,
而外連接會選出其他不匹配的記錄。我們常用的是內(nèi)連接。

外連接有分為左連接和右連接,具體定義如下:

  1. 左連接:包含所有的左邊表中的記錄甚至是右邊表中沒有和它匹配的記錄
  2. 右連接:包含所有的右邊表中的記錄甚至是左邊表中沒有和它匹配的記錄
SELECT ename,deptname FROM emp LEFT JOIN dept ON emp.deptno=dept.deptno;

 6.子查詢

某些情況,當(dāng)我們查詢的時候,需要的條件是另一個SELECT語句的結(jié)果,這個時候,就要用到子查詢。
用于子查詢的關(guān)鍵字主要包括in、not in、=、!=、exists、not exists等。

SELECT * FROM emp WHERE deptno IN(SELECT deptno FROM dept);

注意:子查詢和表連接之間的轉(zhuǎn)換主要應(yīng)用在兩個方面:

MySQL 4.1 以前的版本不支持子查詢,需要用表連接來實現(xiàn)子查詢的功能
表連接在很多情況下用于優(yōu)化子查詢

7.記錄聯(lián)合

我們經(jīng)常會碰到這樣的應(yīng)用,將兩個表的數(shù)據(jù)按照一定的查詢條件查詢出來后,將結(jié)果合并到一起顯示出來,這個時候,就需要用到union和union all關(guān)鍵字來實現(xiàn)這樣的功能,具體語法如下:

SELECT * FROM t1
UNION|UNION ALL
SELECT * FROM t2
......
UNION|UNION ALL
SELECT * FROM tn;

UNION 和 UNION ALL的主要區(qū)別是 UNION ALL 是把結(jié)果集直接合并在一起,而UNION是將UNION ALL后的結(jié)果進(jìn)行一次DISTINCT,去除重復(fù)記錄后的結(jié)果。

以上所述是小編給大家介紹的MySQL DML語句整理匯總詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • MySQL數(shù)據(jù)操作-DML語句的使用
  • MySQL的DML語言操作實例
  • 詳解mysql DML語句的使用
  • 快速學(xué)習(xí)MySQL基礎(chǔ)知識
  • MySQL學(xué)習(xí)之?dāng)?shù)據(jù)庫操作DML詳解小白篇

標(biāo)簽:鄂爾多斯 昌都 黔西 荊門 陜西 駐馬店 梅河口 北京

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL DML語句整理匯總》,本文關(guān)鍵詞  MySQL,DML,語句,整理,匯總,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL DML語句整理匯總》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL DML語句整理匯總的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    同德县| 滨州市| 阳朔县| 辽宁省| 临沭县| 乌拉特前旗| 离岛区| 阳春市| 泰来县| 化隆| 莱阳市| 静海县| 方城县| 北辰区| 杨浦区| 贵港市| 亚东县| 响水县| 胶州市| 东阿县| 杨浦区| 潢川县| 亚东县| 会昌县| 安福县| 崇阳县| 开化县| 应用必备| 湟中县| 万山特区| 孝感市| 北流市| 抚宁县| 龙陵县| 岳西县| 抚远县| 常宁市| 思茅市| 阿图什市| 南京市| 乌兰察布市|