WHCSRL 技术网

MySql列的插入,修改和删除

DML语言

– 数据操作语言
– 插入:insert
– 修改:update
– 删除:delete

一:插入语句

方式1:

– 语法:
– insert into 表名(列名,…) values(值1,…)

案例1:简单使用

INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(20,'张三','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
  • 1
  • 2
  • 3

案例2:有nullable属性的列名可以不写,插入默认值;插入时可以不按顺序

INSERT INTO beauty(NAME,id,phone)
VALUES('张四',21,'212321322');
SELECT * FROM beauty;
  • 1
  • 2
  • 3

案例3:表后面的括号和列名可以不写,默认为表里面的所有列,顺序不能变

INSERT INTO beauty
VALUES(22,'张五','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
  • 1
  • 2
  • 3

案例4:支持插入多行

INSERT INTO beauty
VALUES(26,'张三','女','1922-2-12','21232132',NULL,21),
(24,'张三','女','1922-2-12','21232132',NULL,21),
(25,'张三','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
  • 1
  • 2
  • 3
  • 4
  • 5

案例5:支持子查询

INSERT INTO beauty(id,NAME,phone)
SELECT 98,'12','2123' UNION
SELECT 45,'12','2123';
  • 1
  • 2
  • 3

方式2:

– 语法:
INSERT INTO 表名 SET 列名=值,列名=值,…

案例1:简单使用

INSERT INTO beauty SET id=23,NAME='张柳',phone='12332312321';
SELECT * FROM beauty;
  • 1
  • 2

二:修改语句

– 1.修改单表的语法:
– update 表 set 列名=新值,列表=新值,…
– where 筛选条件

案例1:

UPDATE beauty SET phone='123456789'
WHERE id=9;
  • 1
  • 2

– 2.修改多表语法:(并非修改多个表,而是通过连接表来修改某个表)
– sql92:(只支持内连接)
– update 表1 别名,表2 别名
– set 列=值…
– where 连接条件
– and 筛选条件
– sql99:
– update 表1 别名
– inner|left|right join 表2 别名
– on 连接条件
– set 列=值…
– where 筛选条件

案例1:

UPDATE boys bo
INNER JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET phone='1'
WHERE bo.`boyName` LIKE '%%张%%';
  • 1
  • 2
  • 3
  • 4

案例2:

UPDATE boys bo
RIGHT JOIN beauty b ON b.`boyfriend_id`=bo.id
SET boyfriend_id=2
WHERE bo.id IS NULL;
  • 1
  • 2
  • 3
  • 4

三:删除语句

– 方式一:delete 删除行
– 语法:
– delete from 表名 where 筛选条件
– delete from 表名 连接类型 join 表名 on 连接条件 where 筛选条件(sql99)

案例:单表删除

DELETE FROM beauty WHERE phone LIKE '%%9';
  • 1

案例:多表删除

DELETE b 
FROM  beauty b 
INNER JOIN boys bo
ON bo.id=b.`boyfriend_id`
WHERE bo.boyname LIKE '%%张%%';
  • 1
  • 2
  • 3
  • 4
  • 5

– 方式二:truncate 删除表
– 语法:
– truncate table 表名

案例:

TRUNCATE TABLE boys;
  • 1

注意点

– 如果用delete删除后,再插数据,自增长列的值会是1个新值.用truncate删除则不是.
– delete有返回值,truncate无;
– truncate删除不能回滚,delete删除可以回滚

推荐阅读