1. 程式人生 > 其它 >DML語言

DML語言

技術標籤:mysql資料庫sqloraclejava

DML語言

  • 資料操作語言
插入:insert
修改:update
刪除:delete

插入語句

  • 方式一:經典的插入
  • 語法:insert into 表名(欄位名,…) values(值,…);
  • 特點
    • 1、要求值的型別和欄位的型別要一致或相容;
    • 2、欄位的個數和順序不一定與原始表中的欄位個數和順序一致但必須保證值和欄位一一對應;
    • 3、假如表中有可以為null的欄位,注意可以通過以下兩種方式插入null值
    • 4、欄位和值的個數必須一致
    • 5、欄位名可以省略,預設所有列

具體案例:

SELECT * FROM beauty;
#1.插入的值的型別要與列的型別一致或相容
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(13,'唐藝昕','女','1990-4-23','1898888888',NULL,2);

#2.不可以為null的列必須插入值。可以為null的列如何插入值?
    #方法一:
    INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
    VALUES(13,'唐藝昕','女','1990-4-23','1898888888',NULL,2);

    #方法二:
    INSERT INTO beauty(id,NAME,sex,phone)
    VALUES(15,'娜扎','女','1388888888');

#3.列的順序是否可以調換
INSERT INTO beauty(NAME,sex,id,phone)
VALUES('蔣欣','女',16,'110');

#4.列數和值的個數必須一致
INSERT INTO beauty(NAME,sex,id,phone)
VALUES('關曉彤','女',17,'110');

#5.可以省略列名,預設所有列,而且列的順序和表中列的順序一致
INSERT INTO beauty
VALUES(18,'張飛','男',NULL,'119',NULL,NULL);
  • 方式二語法:insert into 表名 set 列名=值,列名=值,…
  • INSERT INTO beauty SET id=19,NAME=‘劉濤’,phone=‘999’;
  • 兩種方式的區別
1.方式一支援一次插入多行,語法如下:
insert into 表名【(欄位名,..)】 values(值,..),(值,...),...;
2.方式一支援子查詢,語法如下:
    insert into 表名 查詢語句;
    
#1、方式一支援插入多行,方式二不支援

INSERT INTO beauty
VALUES(23,'唐藝昕1','女','1990-4-23','1898888888',NULL,2)
,(24,'唐藝昕2','女','1990-4-23','1898888888',NULL,2)
,(25,'唐藝昕3','女','1990-4-23','1898888888',NULL,2);

#2、方式一支援子查詢,方式二不支援
INSERT INTO beauty(id,NAME,phone) SELECT 26,'宋茜','11809866';

INSERT INTO beauty(id,NAME,phone) 
SELECT id,boyname,'1234567' FROM boys WHERE id<3;       

修改語句

  • 修改單表的記錄★
  • 語法:update 表名 set 列=新值,列=新值,… where 篩選條件;

案例

#1.修改單表的記錄
#案例1:修改beauty表中姓唐的女神的電話為13899888899
UPDATE beauty SET phone = '13899888899'
WHERE NAME LIKE '唐%';

#案例2:修改boys表中id好為2的名稱為張飛,魅力值 10
UPDATE boys SET boyname='張飛',usercp=10
WHERE id=2;
  • 修改多表的記錄【補充】
  • sql92語法:update 表1 別名,表2 別名 set 列=值,… where 連線條件 and 篩選條件;
  • sql99語法:update 表1 別名 inner|left|right join 表2 別名 on 連線條件 set 列=值,… where 篩選條件;

案例

#2.修改多表的記錄
#案例 1:修改張無忌的女朋友的手機號為114
UPDATE boys bo
INNER JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET b.`phone`='119',bo.`userCP`=1000
WHERE bo.`boyName`='張無忌';

#案例2:修改沒有男朋友的女神的男朋友編號都為2號
UPDATE boys bo
RIGHT JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET b.`boyfriend_id`=2 WHERE bo.`id` IS NULL;

刪除語句

  • 方式一:delete

語法

1、單表的刪除【★】
delete from 表名 where 篩選條件

2、多表的刪除【補充】

sql92語法:
delete 表1的別名,表2的別名
from 表1 別名,表2 別名
where 連線條件
and 篩選條件;

sql99語法:
delete 表1的別名,表2的別名
from 表1 別名
inner|left|right join 表2 別名 on 連線條件
where 篩選條件;

案例

#1.單表的刪除
#案例:刪除手機號以9結尾的女神資訊
DELETE FROM beauty WHERE phone LIKE '%9';
SELECT * FROM beauty;

#2.多表的刪除
#案例:刪除張無忌的女朋友的資訊
DELETE b
FROM beauty b
INNER JOIN boys bo ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName`='張無忌';

#案例:刪除黃曉明的資訊以及他女朋友的資訊
DELETE b,bo
FROM beauty b
INNER JOIN boys bo ON b.`boyfriend_id`=bo.`id`
WHERE bo.`boyName`='黃曉明';
  • 方式二:truncate
語法:truncate table 表名;
#案例:將魅力值>100的男神資訊刪除
TRUNCATE TABLE boys ;
  • 兩種方式的區別【面試題】★
1.delete 可以加where 條件,truncate不能加
2.truncate刪除,效率高一點
3.假如要刪除的表中有自增長列,
  如果用delete刪除後,再插入資料,自增長列的值從斷點開始,而truncate刪除後,再插入資料,自增長列的值從1開始。
4.truncate刪除沒有返回值,delete刪除有返回值
5.truncate刪除不能回滾,delete刪除可以回滾.