日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解mysql DML語句的使用

瀏覽:268日期:2023-10-13 12:05:41

前言:

在上篇文章中,主要為大家介紹的是DDL語句的用法,可能細心的同學已經發現了。本篇文章將主要聚焦于DML語句,為大家講解表數據相關操作。

這里說明下DDL與DML語句的分類,可能有的同學還不太清楚。

DDL(Data Definition Language):數據定義語言,用于創建、刪除、修改、庫或表結構,對數據庫或表的結構操作。常見的有create,alter,drop等。

DML(Data Manipulation Language):數據操縱語言,主要對表記錄進行更新(增、刪、改)。常見的有insert,update,delete等。

1.插入數據

插入數據主要用到的是insert語法,官方文檔同樣給出很多選項:

INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [PARTITION (partition_name [, partition_name] ...)] [(col_name [, col_name] ...)] {VALUES | VALUE} (value_list) [, (value_list)] ... [ON DUPLICATE KEY UPDATE assignment_list]INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [PARTITION (partition_name [, partition_name] ...)] SET assignment_list [ON DUPLICATE KEY UPDATE assignment_list]INSERT [LOW_PRIORITY | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [PARTITION (partition_name [, partition_name] ...)] [(col_name [, col_name] ...)] SELECT ... [ON DUPLICATE KEY UPDATE assignment_list]value: {expr | DEFAULT}value_list: value [, value] ...assignment: col_name = valueassignment_list: assignment [, assignment] ...

有興趣的同學可以咨詢研究下上面的各個選項哦,下面我將分類給大家介紹幾個常用的語法。

INSERT INTO ... VALUES (...)

這可能是你寫insert語句最常用的一種,標準用法為:

INSERT INTO <表名> [ <列名1> [ , … <列名n>] ]VALUES (值1) [… , (值n) ];INSERT INTO table(column1,column2...)VALUES (value1,value2,...), (value1,value2,...),...;

語法說明如下:

<表名> :指定被操作的表名。 <列名> :指定需要插入數據的列名。若向表中的所有列插入數據,則全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。 VALUES 或 VALUE 子句:該子句包含要插入的數據清單。數據清單中數據的順序要和列的順序相對應。

INSERT ... SET ...

insert ... set語句一次只能插入一條數據,可以向表中插入部分列的值,這種方式更為靈活。

INSERT INTO <表名>SET <列名1> = <值1>, <列名2> = <值2>, …

INSERT INTO ... SELECT ...

INSERT INTO…SELECT…FROM 語句用于快速地從一個或多個表中取出數據,并將這些數據作為行數據插入另一個表中。

SELECT 子句返回的是一個查詢到的結果集,INSERT 語句將這個結果集插入指定表中,結果集中的每行數據的字段數、字段的數據類型都必須與被操作的表完全一致。

舉個例子,假如test表和test_bak表結構完全一致,我們想把test表中的數據插入到test_bak表中,那么我們可以這么操作:

INSERT INTO test_bak select * from test;

INSERT ... ON DUPLICATE KEY UPDATE

如果要插入的新行違反主鍵(PRIMARY KEY)或UNIQUE約束,則MySQL會報錯,此語法就是為了解決此錯誤。當數據庫中存在某個記錄時,執行這條語句會更新它,而不存在這條記錄時,會插入它。

下面舉個例子為大家演示下效果:

CREATE TABLE `student` ( `xuehao` int(11) primary key, `name` varchar(255) DEFAULT NULL, `age` int(11) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;mysql> select * from student;+--------+------+------+| xuehao | name | age |+--------+------+------+| 1001 | aaa | 18 || 1002 | bbb | 19 || 1003 | ccc | 20 |+--------+------+------+insert into student (xuehao,name,age) values (1003,’ccc’,19) on DUPLICATE KEY UPDATE age = 19;mysql> select * from student;+--------+------+------+| xuehao | name | age |+--------+------+------+| 1001 | aaa | 18 || 1002 | bbb | 19 || 1003 | ccc | 19 |+--------+------+------+update student set age = 19 where xuehao = 1003;

REPLACE INTO ... VALUES ...

replace into 跟 insert 功能類似,不同點在于:replace into 首先嘗試插入數據到表中, 1. 如果發現表中已經有此行數據(根據主鍵或者唯一索引判斷)則先刪除此行數據,然后插入新的數據。2. 否則,直接插入新數據。

同樣舉個例子說明下:

mysql> select * from student;+--------+------+------+| xuehao | name | age |+--------+------+------+| 1001 | aaa | 18 || 1002 | bbb | 19 || 1003 | ccc | 19 |+--------+------+------+replace into student values (1003,’ccc’,17);mysql> select * from student;+--------+------+------+| xuehao | name | age |+--------+------+------+| 1001 | aaa | 18 || 1002 | bbb | 19 || 1003 | ccc | 17 |+--------+------+------+

2.更新數據

update語句用于更新表數據,官方推薦語法為:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference SET assignment_list [WHERE where_condition] [ORDER BY ...] [LIMIT row_count]value: {expr | DEFAULT}assignment: col_name = valueassignment_list: assignment [, assignment] ...

同樣的,這里只給大家介紹常用的單表更新語法:

UPDATE <表名> SET 字段 1=值 1 [,字段 2=值 2… ] [WHERE 子句 ][ORDER BY 子句] [LIMIT 子句]

語法說明如下:

<表名>:用于指定要更新的表名稱。 SET 子句:用于指定表中要修改的列名及其列值。其中,每個指定的列值可以是表達式,也可以是該列對應的默認值。如果指定的是默認值,可用關鍵字 DEFAULT 表示列值。 WHERE 子句:可選項。用于限定表中要修改的行。若不指定,則修改表中所有的行。 ORDER BY 子句:可選項。用于限定表中的行被修改的次序。 LIMIT 子句:可選項。用于限定被修改的行數。

3.刪除數據

delete語句用于刪除表數據,官方文檔推薦語法:

DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name [PARTITION (partition_name [, partition_name] ...)] [WHERE where_condition] [ORDER BY ...] [LIMIT row_count]

使用 DELETE 語句從單個表中刪除數據,語法格式為:

DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

語法說明如下:

<表名>:指定要刪除數據的表名。 ORDER BY 子句:可選項。表示刪除時,表中各行將按照子句中指定的順序進行刪除。 WHERE 子句:可選項。表示為刪除操作限定刪除條件,若省略該子句,則代表刪除該表中的所有行。 LIMIT 子句:可選項。用于告知服務器在控制命令被返回到客戶端前被刪除行的最大值。

總結:

本文主要介紹了三種DML語句的語法,看似簡單,其實其中各種選項還是很復雜的,特別是insert語句,經常用到的選項就有很多。在這里也要提醒大家,執行update或delete語句時一定要小心,不使用where條件會更新或刪除全部數據哦。

以上就是詳解mysql DML語句的使用的詳細內容,更多關于mysql DML語句的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品三级在线| 国产日韩欧美一区二区三区 | 蜜臀av一区二区三区| 精品日韩一区| 日本精品在线播放| 麻豆91精品| 亚洲啊v在线| 国产一区二区三区免费在线 | 另类欧美日韩国产在线| 91福利精品在线观看| 亚洲欧洲av| 日韩精品一区第一页| 欧美日韩免费观看一区=区三区| 91精品亚洲| 亚洲午夜精品久久久久久app| 日韩欧美国产精品综合嫩v| 精品一区二区三区亚洲| 91嫩草亚洲精品| 97精品国产一区二区三区| 六月丁香综合在线视频| 精品女同一区二区三区在线观看| 久久爱www成人| 国产精品二区影院| 久久福利在线| 日韩精品诱惑一区?区三区| 免费高潮视频95在线观看网站| 亚洲一级少妇| 蜜臀久久99精品久久久画质超高清 | 欧美日韩国产高清| 午夜影院欧美| 91嫩草精品| 国产色播av在线| 日韩一区精品字幕| 国产成人77亚洲精品www| 欧美午夜精品一区二区三区电影| 亚洲一区网站| 久久这里只有精品一区二区| 香蕉国产精品| 免费一级欧美片在线观看网站| 日韩欧美一区二区三区免费观看| 一本色道精品久久一区二区三区| 国产亚洲高清一区| 欧美午夜精品一区二区三区电影| 日本国产欧美| av综合电影网站| 亚洲无线观看| 国产综合婷婷| 国产欧美高清| 水野朝阳av一区二区三区| 精品视频一区二区三区四区五区 | 99视频精品全部免费在线视频| 日韩二区在线观看| 久久久久美女| 成人在线免费观看网站| 婷婷综合成人| 激情久久久久久久| 国产视频一区二区在线播放| 欧美精品一区二区久久| 麻豆国产精品777777在线| 亚洲一区中文| 亚洲午夜91| 成人精品亚洲| 日韩一区自拍| 国产一区二区三区四区大秀| 日韩一二三区在线观看| 中文在线一区| 91国语精品自产拍| 日韩大片在线播放| 日韩视频网站在线观看| 精品国产乱码久久久久久1区2匹| 免费国产亚洲视频| 国产一区成人| 日韩中文字幕区一区有砖一区 | 亚洲精品高潮| 亚洲不卡视频| 亚洲精品乱码日韩| 日本在线观看不卡视频| 亚洲精品护士| 天堂va欧美ⅴa亚洲va一国产| 综合激情婷婷| 日韩精品1区2区3区| 亚洲精品黄色| 欧美伊人影院| 国产精品第一国产精品| 粉嫩av一区二区三区四区五区 | 日韩在线短视频| 亚洲手机视频| 中文无码久久精品| 久久精品av麻豆的观看方式| 久久av免费| 欧美aa在线观看| 久久亚洲电影| 欧美中文一区| 国产精品探花在线观看| 国产精品xx| 玖玖玖国产精品| 精品淫伦v久久水蜜桃| 韩国三级一区| 日本不卡一二三区黄网| sm久久捆绑调教精品一区| 美国三级日本三级久久99 | 91看片一区| 亚洲欧美日韩精品一区二区 | 国产欧美日韩| 一本大道色婷婷在线| 亚洲欧美日韩视频二区| 久久国产精品免费精品3p| 国产自产自拍视频在线观看| 国产亚洲激情| 国产日产高清欧美一区二区三区 | 日本在线一区二区三区| 麻豆精品久久| 欧美福利专区| 亚洲3区在线| 欧美激情另类| 日本亚洲三级在线| 麻豆久久久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品一区视频| 亚洲精品观看| 成人日韩在线观看| 日韩精品高清不卡| 成人免费网站www网站高清| 欧美va天堂在线| 欧美激情在线精品一区二区三区| 蜜臀av免费一区二区三区| 国产欧美日韩精品高清二区综合区| 亚洲精品福利电影| 亚洲精品观看| 激情婷婷亚洲| 精品丝袜久久| 亚洲欧美在线专区| 欧美+日本+国产+在线a∨观看| 国产精品www.| 蜜桃久久久久久久| 欧美日一区二区| 日本va欧美va精品发布| 亚洲国产成人精品女人| 欧美精品91| 国产精品久久| 亚洲影视一区二区三区| 亚洲深夜影院| 在线视频观看日韩| 正在播放日韩精品| 国产精品一级| 日本不卡一区二区| 日韩精品一区二区三区中文 | 欧美成人午夜| 激情自拍一区| 精品国产乱码久久久| 综合激情一区| 亚洲精品极品| 日韩av不卡一区二区| 亚洲久草在线| 国产欧美久久一区二区三区| 老牛国内精品亚洲成av人片| 国产探花一区在线观看| 国产伦理一区| 久久免费福利| 99久久夜色精品国产亚洲狼| 欧美成人久久| 1024精品久久久久久久久| 91超碰国产精品| 免费精品视频| 日本va欧美va欧美va精品| 蜜臀av免费一区二区三区| 欧美日韩国产精品一区二区亚洲| 人人精品人人爱| 国产精品免费不| 日韩av中文在线观看| 久久精品系列| 午夜在线精品偷拍| 啪啪亚洲精品| 国产夫妻在线| 久久精品国产精品亚洲毛片| 蜜臀久久精品| 亚洲一区二区三区久久久| 国产精品一区二区99| 成人日韩精品| 亚洲精品欧洲| 国产精品香蕉| 久久三级福利| 日韩国产在线观看| 久久97视频| 午夜在线视频观看日韩17c| 日本不卡视频在线观看 | 国产亚洲精品美女久久久久久久久久| 国产美女视频一区二区| 久久国产日本精品| 日本不卡视频一二三区| 国产成人精品一区二区免费看京| 午夜在线视频观看日韩17c| 免费在线欧美黄色| 在线 亚洲欧美在线综合一区| 中文字幕视频精品一区二区三区| 色婷婷色综合| 国产日韩亚洲| 人人爽香蕉精品| 欧美日韩国产免费观看| 精品国产不卡|