一、增加数据
语法:
INSERT [INTO]
表名
[(
列名表
)] VALUES (
值列表
)
1.1
插入全部字段
l
所有的字段名都写出来
INSERT INTO 表名 (字段名1, 字段名2, 字段名3…) VALUES (值1, 值2, 值3);
l
不写字段名
INSERT INTO 表名 VALUES (值1, 值2, 值3…);
注:没有添加数据的字段会使用
NULL
1.2
插入部分数据
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
注:没有添加数据的字段会使用
NULL
具体操作
-- 建议练习可建一个测试用小表
create table test(
userName varchar(20),
`passWord` varchar(10),
age int,
sex char(2)
)
insert into test values('qqq','000000',20,'na');
l
插入部分的列,向学生表中
insert into student (id,name,age,sex) values (1, '孙悟空', 20, '男');
insert into student (id,name,age,sex) values (2, '孙悟天', 16, '男');
l 向表中插入所有字段
-- 插入所有列
insert into student values (3, '孙悟饭', 18, '男', '龟仙人洞中');
-- 如果只插入部分列,必须写列名
insert into student values (3, '孙悟饭', 18, '男');
select * from student;
注意事项:
1
、
如何写入当前的时间
now() , sysdate() , CURRENT_DATE()
select sysdate()
insert into t_student values (7,"张三",'男',18,now(),'软件1班','123@126.com');
2
、如果不是全字段插入数据的话,需要加入字段的名字
3
、当插入表中全部列数据时,表名后可省略列名,值列表的列数和顺序与表定义中一致。
4
、列名必须和值列表一一对应,列数、顺序、数据类型必须一致。
5
、自增列不能插入数据,非空列必须有对应值,插入数据时注意各种约束的限制。
INSERT into `grade` (GradeName)VALUES ('tttt');-- 自增列不能插入数据其它每个字段
强制对应
INSERT into `grade` VALUES (default,'pppp'); -- null代替 也可以
6
、具有默认值的列,可以使用
DEFAULT
(默认)关键字来代替插入的数值。
INSERT INTO Students (SName,SAddress,SGrade,SEmail,SSEX)
VALUES ('张青裁',DEFAULT,6,'ZQC@Sohu.com',0)
--DEFAULT 插入默认值
insert into student(sno,sname,sage,class) values(1, ‘crazyant’, ’25ʹ,
DEFAULT)
-- 这时候就直接将班级class的默认值插入进去了。
二、修改数据
UPDATE
表名
SET
列名
1 =
更新值
1
,列名
2 =
更新值
2... [WHERE
更新条件
]
2.1
不带条件修改数据
UPDATE
表名
SET
字段名
=
值
; --
修改所有的行
2.2
带条件修改数据
UPDATE
表名
SET
字段名
=
值
WHERE
字段名
=
值
;
具体操作
:
-- 不带条件修改多列数据,将所有的 性别改为"女" 地址改为"北京女子职业技术学校家政班"
UPDATE Students SET SEX = '女',SAddress ='北京女子职业技术学校家政班';
-- 不带条件修改数据,将所有的地址改为"北京女子职业技术学校家政班"
UPDATE Students SET SAddress ='北京女子职业技术学校家政班';
WHERE SAddress = '北京女子职业技术学校刺绣班'
UPDATE ScoresSET Scores = Scores + 5 WHERE Scores <= 95
注意:
1
、更新多列数据使用逗号隔开
2
、勿忘条件限制,以防有效数据的丢失
3
、
is null
用于判断某列值是否为空
三、 删除表记录
3.1
不带条件删除数据
DELETE FROM
表名
;
3.2
带条件删除数据
DELETE FROM
表名
WHERE
字段名
=
值
;
3.3
使用
truncate
删除表中所有记录
TRUNCATE TABLE
表名
;
3.4 truncate
和
delete
的区别:
truncate
相当于删除表的结构,再创建一张表。
具体操作:
-- 带条件删除数据,删除id为1的记录
delete from student where id=1;
-- 不带条件删除数据,删除表中的所有数据
delete from student;
四、批量增加
INSERT INTO
表名
(
字段名
1,
字段名
2,
字段名
3…) VALUES (
值
1,
值
2,
值
3...), (
值
1,
值
2,
值
3...), (
值
1,
值
2, 值3...)...;
或者
INSERT INTO
表名
VALUES (
值
1,
值
2,
值
3...), (
值
1,
值
2,
值
3...), (
值
1,
值
2,
值
3...)...;
insert into test values('mmm','000000',21,default),
('nnn','000000',21,default);
感谢大家的阅读,如有不对的地方,可以私信我,感谢大家!