电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

MySQL數據操作-DML語句的使用

瀏覽:8日期:2023-10-09 12:55:37

說明

DML(Data Manipulation Language)數據操作語言,是指對數據庫進行增刪改的操作指令,主要有INSERT、UPDATE、DELETE三種,代表插入、更新與刪除,這是學習MySQL必要掌握的基本知識。

方語法中 [] 中內容可以省略。

INSERT操作

逐行插入

語法格式如下:

insert into t_name[(column_name1,columnname_2,...)] values (val1,val2); 或者 insert into t_name set column_name1 = val1,column_name2 = val2;

1、字段名稱和值需要保證數量一直,類型一直,位置一 一對應,否則可能導致異常。

2、not null的字段需要保證有插入的值,否則會報非空的異常信息。允許null的字段如果不想輸入數據,字段和值都不出現,或者value用null代替。

3、數值類型,值不需要用單引號括起來,其他的如字符型或日期類型,值需要用單引號括起來;

4、如果表名后面的column_name 省略不寫,則代表覆蓋該表的所有字段。值的順序和表中字段順序須保持一致。

5、上述第二種語法的寫法更繁瑣,現在比較少使用。

測試一下:

mysql> desc `user1`;+---------+--------------+------+-----+---------+----------------+| Field | Type | Null | Key | Default | Extra |+---------+--------------+------+-----+---------+----------------+| id | bigint(20) | NO | PRI | NULL | auto_increment || name | varchar(20) | NO | | NULL ||| age | int(11) | NO | | 0 ||| address | varchar(255) | YES | | NULL ||+---------+--------------+------+-----+---------+----------------+4 rows in setmysql> insert into `user1`(name,age,address) values(’brand’,20,’fuzhou’);Query OK, 1 row affectedmysql> insert into `user1`(age,address) values(20,’fuzhou’);1364 - Field ’name’ doesn’t have a default valuemysql> insert into `user1` values(’sol’,21,’xiamen’);1136 - Column count doesn’t match value count at row 1mysql> insert into `user1` values(null,’sol’,21,’xiamen’);Query OK, 1 row affectedmysql> select * from `user1`;+----+-------+-----+---------+| id | name | age | address |+----+-------+-----+---------+| 3 | brand | 20 | fuzhou || 4 | sol | 21 | xiamen |+----+-------+-----+---------+2 rows in set

批量插入

語法格式如下:

insert into t_name [(column_name1,column_name2)] values (val1_1,val1_2),(val2_1,val2_2)...); 或者 insert into t_name [(column_name1,column_name2)] select o_name1,o_name2 from o_t_name [where condition];

1、上述第一個語法,values 后面的值個數需要同等配對 column的數量,可以設置多個,逗號隔開,提高數據插入效率。

2、第二個語法,select查詢的字段和插入數據的字段數量、順序、類型需要一致。 insert的字段可以省略,代表插入t_name表所有字段。條件可選。

測試一下:

mysql> insert into `user1`(name,age,address) values(’brand’,20,’fuzhou’),(’sol’,21,’xiamen’);Query OK, 2 rows affectedRecords: 2 Duplicates: 0 Warnings: 0mysql> select * from `user1`;+----+-------+-----+---------+| id | name | age | address |+----+-------+-----+---------+| 5 | brand | 20 | fuzhou || 6 | sol | 21 | xiamen |+----+-------+-----+---------+2 rows in set

mysql> desc `user2`;+---------+--------------+------+-----+---------+----------------+| Field | Type | Null | Key | Default | Extra |+---------+--------------+------+-----+---------+----------------+| id | bigint(20) | NO | PRI | NULL | auto_increment || name | varchar(20) | NO | | NULL ||| age | int(11) | NO | | 0 ||| address | varchar(255) | YES | | NULL ||| sex | int(11) | NO | | 1 ||+---------+--------------+------+-----+---------+----------------+5 rows in setmysql> insert into `user2` (name,age,address,sex) select name,age,address,null from `user1`;Query OK, 2 rows affectedRecords: 2 Duplicates: 0 Warnings: 0mysql> select * from `user2`;+----+-------+-----+---------+------+| id | name | age | address | sex |+----+-------+-----+---------+------+| 7 | brand | 20 | fuzhou | 1 || 8 | sol | 21 | xiamen | 1 |+----+-------+-----+---------+------+2 rows in set

UPDATE操作

數據更新

語法格式如下:

update t_name [[as] alias] set [ alias.]column_name1 = val1,[alias.]column_name2 = val2 [where condition];

1、alias 是別名的意思,別名越簡單識別性越強越好,容易辨認,方便操作,沒有別名情況下,表名就是別名

2、as alias 中as也是可選的,where 條件也是可選的,所以用戶可以選擇需要的,符合特定條件的部分數據進行更新。

測試一下:

mysql> select * from `user2`;+----+-------+-----+---------+------+| id | name | age | address | sex |+----+-------+-----+---------+------+| 7 | brand | 20 | fuzhou | NULL || 8 | sol | 21 | xiamen | NULL |+----+-------+-----+---------+------+2 rows in setmysql> update `user2` as u2 set u2.name = ’hero’,u2.age=23,u2.sex=1 where id=7;Query OK, 1 row affectedRows matched: 1 Changed: 1 Warnings: 0mysql> select * from `user2`;+----+------+-----+---------+------+| id | name | age | address | sex |+----+------+-----+---------+------+| 7 | hero | 23 | fuzhou | 1 || 8 | sol | 21 | xiamen | NULL |+----+------+-----+---------+------+2 rows in set

還有一種方式是同時更新多個表,使用不同的別名以及一些條件去限制,不過不建議這么做,操作易錯,并且不好維護。

DELETE操作

delete方式刪除

語法格式如下:

delete [alias] from t_name [[as] alias] [where condition];

1、跟上面一樣,alias代表別名,沒有別名情況下,表名就是別名

2、如果表設置了別名,則delete后面必須跟上別名,否則數據庫會報異常。

測試一下:

mysql> select * from `user2`;+----+------+-----+---------+------+| id | name | age | address | sex |+----+------+-----+---------+------+| 7 | hero | 23 | fuzhou | 1 || 8 | sol | 21 | xiamen | NULL |+----+------+-----+---------+------+2 rows in setmysql> delete from `user2` as alias where sex=1;1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ’as alias where sex=1’ at line 1mysql> delete alias from `user2` as alias where sex=1;Query OK, 1 row affectedmysql> select * from `user2`;+----+------+-----+---------+------+| id | name | age | address | sex |+----+------+-----+---------+------+| 8 | sol | 21 | xiamen | NULL |+----+------+-----+---------+------+1 row in set

3、如果刪除表中所有的數據,則后面不帶上where條件即可,不過要謹慎使用喲。

mysql> select * from `user2`;+----+-------+-----+----------+-----+| id | name | age | address | sex |+----+-------+-----+----------+-----+| 8 | sol | 21 | xiamen | 0 || 10 | brand | 21 | fuzhou | 1 || 11 | helen | 20 | quanzhou | 0 |+----+-------+-----+----------+-----+3 rows in setmysql> delete from `user2`;Query OK, 3 rows affectedmysql> select * from `user2`;Empty set

truncate方式刪除

語法格式如下:

truncate t_name;

mysql> select * from `user2`;+----+-------+-----+----------+-----+| id | name | age | address | sex |+----+-------+-----+----------+-----+| 12 | brand | 21 | fuzhou | 1 || 13 | helen | 20 | quanzhou | 0 || 14 | sol | 21 | xiamen | 0 |+----+-------+-----+----------+-----+3 rows in setmysql> truncate `user2`;Query OK, 0 rows affectedmysql> select * from `user2`;Empty set

看起來跟delete很像,但是重新插入數據會發現,他的自增主鍵會重新從1開始,但是delete的是直接在原來的所以自增值之后往上加。看下面id字段。

mysql> insert into `user2` (name,age,address,sex) values(’brand’,21,’fuzhou’,1),(’helen’,20,’quanzhou’,0),(’sol’,21,’xiamen’,0);Query OK, 3 rows affectedRecords: 3 Duplicates: 0 Warnings: 0mysql> select * from `user2`;+----+-------+-----+----------+-----+| id | name | age | address | sex |+----+-------+-----+----------+-----+| 1 | brand | 21 | fuzhou | 1 || 2 | helen | 20 | quanzhou | 0 || 3 | sol | 21 | xiamen | 0 |+----+-------+-----+----------+-----+3 rows in set

那 truncate 和 delete有什么區別呢?我們來梳理下。

truncate和delete的比較

1、truncate 指的是清空表的數據、釋放表的空間,但不刪除表的架構定義(表結構)。因為不包含Where條件,所以不是刪除具體行,而是將整個表清空了。

2、而delete 語句是刪除表中的數據行,可以在后面帶上條件控制刪除的維度、范圍,它每次從表中刪除一行,會同時將該行的刪除操作作為事務保存在日志中,用于進行可能的回滾操作。

3、truncate 和 delete 一樣的地方是:只是刪除數據,涉及到的表結構及其列、約束、索引等均不會變。

4、如果被外鍵 foreign key 約束,不能使用truncate ,只能使用不帶where子句的delete語句。

5、truncate 操作會記錄在日志中,delete操作會放到 rollback segement 中,執行時要等事務被commit才會生效;所以delete 會觸發刪除觸發器(如果有的話),truncate 不會。

6、如果像上面我們測試的那樣,包含自增字段,truncate方式清空之后,自增列的值會被初始化從1開始。

delete方式要分情況判斷(如果數據全部delete,數據庫未被重啟,則按照之前max+1;數據庫重啟了,則一樣會重新開始計算自增列的初始值)。

7、還有drop,drop語句會刪除表包括 結構、數據、依賴該表的約束(constrain),觸發器(trigger)索引(index)等。

以上就是MySQL數據操作-DML語句的使用的詳細內容,更多關于MySQL dml語句的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: TYPE-C厂家|TYPE-C接口|TYPE-C防水母座|TYPE-C贴片-深圳步步精 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 驾驶式洗地机/扫地机_全自动洗地机_工业洗地机_荣事达工厂官网 | 石家庄律师_石家庄刑事辩护律师_石家庄取保候审-河北万垚律师事务所 | 劳动法网-专业的劳动法和劳动争议仲裁服务网 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 好看的韩国漫画_韩漫在线免费阅读-汗汗漫画 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 石家庄律师_石家庄刑事辩护律师_石家庄取保候审-河北万垚律师事务所 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 艺术漆十大品牌_艺术涂料加盟代理_蒙太奇艺术涂料厂家品牌|艺术漆|微水泥|硅藻泥|乳胶漆 | 无痕胶_可移胶_无痕双面胶带_可移无痕胶厂家-东莞凯峰 | 注浆压力变送器-高温熔体传感器-矿用压力传感器|ZHYQ朝辉 | 北京租车公司_汽车/客车/班车/大巴车租赁_商务会议/展会用车/旅游大巴出租_北京桐顺创业租车公司 | 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 上海冠顶工业设备有限公司-隧道炉,烘箱,UV固化机,涂装设备,高温炉,工业机器人生产厂家 | 电竞学校_电子竞技培训学校学院-梦竞未来电竞学校官网 | 自动化生产线-自动化装配线-直流电机自动化生产线-东莞市慧百自动化有限公司 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | HYDAC过滤器,HYDAC滤芯,现货ATOS油泵,ATOS比例阀-东莞市广联自动化科技有限公司 | 东莞韩创-专业绝缘骨架|马达塑胶零件|塑胶电机配件|塑封电机骨架厂家 | 萃取箱-萃取槽-PVC萃取箱厂家-混合澄清槽- 杭州南方化工设备 | 合肥办公室装修 - 合肥工装公司 - 天思装饰 | 保镖公司-私人保镖-深圳保镖公司【环宇兄弟保镖】 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 在线钠离子分析仪-硅酸根离子浓度测定仪-油液水分测定仪价格-北京时代新维测控设备有限公司 | 【甲方装饰】合肥工装公司-合肥装修设计公司,专业从事安徽办公室、店面、售楼部、餐饮店、厂房装修设计服务 | 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 西装定制/做厂家/公司_西装订做/制价格/费用-北京圣达信西装 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 光伏家 - 太阳能光伏发电_分布式光伏发电_太阳能光伏网 | 杭州中央空调维修_冷却塔/新风机柜/热水器/锅炉除垢清洗_除垢剂_风机盘管_冷凝器清洗-杭州亿诺能源有限公司 | 成人纸尿裤,成人尿不湿,成人护理垫-山东康舜日用品有限公司 | 土壤检测仪器_行星式球磨仪_土壤团粒分析仪厂家_山东莱恩德智能科技有限公司 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 一体化净水器_一体化净水设备_一体化水处理设备-江苏旭浩鑫环保科技有限公司 | 成都茶楼装修公司 - 会所设计/KTV装修 - 成都朗煜装饰公司 | 定制/定做衬衫厂家/公司-衬衫订做/订制价格/费用-北京圣达信 | 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 双效节能浓缩器-热回流提取浓缩机组-温州市利宏机械 |