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

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

詳解mysql DML語句的使用

瀏覽:265日期: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久久,三上悠亚国产精品一区二区三区
亚洲一区二区免费看| 日韩欧美四区| 国产精品久久久久久久久久久久久久久| 欧美一区=区| 综合激情一区| 婷婷综合成人| 欧美日韩精品一区二区三区在线观看| 四虎精品永久免费| 日韩精品导航| 国产精品视频一区二区三区综合 | 精品一区二区三区中文字幕| 91欧美极品| 久久99久久久精品欧美| 狠狠久久伊人中文字幕| 伊人久久高清| 欧美在线观看视频一区| 夜夜嗨一区二区三区| 蜜桃免费网站一区二区三区| 亚洲精品伊人| 久久99偷拍| 亚洲播播91| 亚洲欧美日韩在线观看a三区| 日韩不卡一区二区三区| 精品视频99| 亚洲爱爱视频| 三级欧美在线一区| 欧美偷窥清纯综合图区| 国产一区二区久久久久| 激情欧美丁香| 日韩超碰人人爽人人做人人添| 欧美a级一区二区| 精品国产黄a∨片高清在线| 午夜av成人| 午夜久久av| 国产精品成久久久久| 亚洲成人一区| 日韩av成人高清| 91嫩草亚洲精品| 国产亚洲精品v| 91在线成人| 精精国产xxxx视频在线野外| 中文一区一区三区免费在线观| 欧美一区精品| 欧洲av一区二区| 亚洲aⅴ网站| 国产一区二区色噜噜| 国产亚洲激情| 精品久久久久久久| 亚洲少妇在线| 大香伊人久久精品一区二区 | 欧美aa在线观看| 亚洲自拍另类| 精品三级久久久| 国产综合视频| 欧美日本二区| 欧美+日本+国产+在线a∨观看| 97成人超碰| 亚洲第一区色| 国产欧美高清视频在线| 国产二区精品| 国产精久久一区二区| 亚洲精品极品少妇16p| 国产精品久一| 性欧美精品高清| 国产精品国产一区| 日日夜夜免费精品视频| 日韩久久电影| 欧美另类中文字幕| 免费观看不卡av| 精品中文字幕一区二区三区四区| 黄色在线一区| 国产高潮在线| 国产欧美日韩影院| 欧美一级专区| 成人福利视频| 久久国内精品| 亚洲一区二区日韩| 天堂网av成人| 国产精品对白| 亚洲精品第一| 亚洲成人一区| 亚洲一级少妇| 免费在线亚洲欧美| 水蜜桃久久夜色精品一区的特点 | 亚洲综合小说| 亚洲特色特黄| 国产第一亚洲| 国产精品毛片久久久| 蜜臀久久久久久久| 婷婷成人综合| 久久91导航| 国内精品亚洲| 国产精品啊啊啊| 色狠狠一区二区三区| 亚洲婷婷在线| 日韩一区自拍| 日产精品一区二区| 69堂精品视频在线播放| 欧美日韩网址| 捆绑调教美女网站视频一区| 日韩专区精品| 日韩视频1区| 99香蕉国产精品偷在线观看| 欧美福利专区| 在线观看亚洲精品福利片| 水蜜桃精品av一区二区| 亚洲女同一区| 精品一区二区三区的国产在线观看| 国产精品精品| 日韩区欧美区| 国产一区二区亚洲| 国产精品视频一区二区三区综合 | 日本91福利区| 欧美少妇精品| 精品一区三区| 国产精品成人一区二区不卡| 日韩中文字幕视频网| 精品捆绑调教一区二区三区| 国产精品午夜av| 免费看黄色91| 久久中文视频| 日本一二区不卡| 久久精品一区二区不卡| 日韩精品欧美精品| 五月精品视频| 欧洲av一区二区| 国产精品高颜值在线观看| 午夜视频一区二区在线观看| 免费看av不卡| 国产精品99久久免费观看| 亚洲韩日在线| 精品视频国内| 久久精品国产亚洲一区二区三区| 亚洲精选久久| 久久国产人妖系列| 91精品一区| 水蜜桃久久夜色精品一区的特点| 日韩不卡视频在线观看| 日本一区二区三区视频在线看| 欧美国产中文高清| 久久免费精品| 国产一区国产二区国产三区 | 国产日韩欧美一区| 国产精品综合色区在线观看| 欧美网站在线| 国产一区二区精品福利地址| 麻豆亚洲精品| 免费日韩一区二区| 日韩高清一区在线 | 日本免费一区二区视频| 久久国产精品久久w女人spa| 极品日韩av| 亚洲视频二区| 国产精品美女午夜爽爽| 日韩电影二区| 午夜久久99| 日本中文字幕不卡| 国产精品天天看天天狠| 成人久久一区| 国产精品久久久久久久久久妞妞 | av中文资源在线资源免费观看| 亚洲一级少妇| 欧美二三四区| 石原莉奈在线亚洲二区| 国产精品视频一区视频二区| 999国产精品| 亚洲视频国产精品| 国产欧美一区二区三区精品观看 | 国产精品字幕| 91福利精品在线观看| 动漫av一区| 欧美女激情福利| 成人亚洲精品| 在线亚洲观看| 激情欧美一区| 粉嫩av一区二区三区四区五区 | 日韩不卡免费高清视频| 日本免费在线视频不卡一不卡二| 国产福利一区二区精品秒拍| 精品国产亚洲日本| 精品午夜久久| 午夜精品网站| 久久激情五月激情| 久久午夜影视| 欧美日韩日本国产亚洲在线| 精品不卡一区| 视频精品一区| 国产精品伦理久久久久久| 久久亚洲二区| 日本不良网站在线观看| 亚洲电影在线一区二区三区| 亚洲综合精品| 欧美日韩一区二区综合| аⅴ资源天堂资源库在线| 国产精品久久乐| 久久国产日韩欧美精品| 久久高清免费观看| 肉色欧美久久久久久久免费看| 日韩精品第二页| 日韩欧美中文字幕一区二区三区|