mysql數據的增刪改-內含經典面試題


#DML語言
/*
數據操作語言:
插入:insert
修改:update
刪除:delete

*/

#一、插入語句
#方式一:經典的插入
/*
語法:
insert into 表名(列名,...) values(值1,...);

*/
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';


#兩種方式大pk ★


#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;

#二、修改語句

/*

1.修改單表的記錄★

語法:
update 表名
set 列=新值,列=新值,...
where 篩選條件;

2.修改多表的記錄【補充】

語法:
sql92語法:
update 表1 別名,表2 別名
set 列=值,...
where 連接條件
and 篩選條件;

sql99語法:
update 表1 別名
inner|left|right join 表2 別名
on 連接條件
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;



#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;

SELECT * FROM boys;


#三、刪除語句
/*

方式一: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 篩選條件;



方式二:truncate
語法:truncate table 表名;

*/

#方式一:delete
#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語句

#案例:將魅力值>100的男神信息刪除
TRUNCATE TABLE boys ;



#delete pk truncate【面試題★】

/*

1.delete 可以加where 條件,truncate不能加

2.truncate刪除,效率高一丟丟
3.假如要刪除的表中有自增長列,
如果用delete刪除后,再插入數據,自增長列的值從斷點開始,
而truncate刪除后,再插入數據,自增長列的值從1開始。
4.truncate刪除沒有返回值,delete刪除有返回值

5.truncate刪除不能回滾,delete刪除可以回滾.

*/

SELECT * FROM boys;

DELETE FROM boys;
TRUNCATE TABLE boys;
INSERT INTO boys (boyname,usercp)
VALUES('張飛',100),('劉備',100),('關雲長',100);

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM