插入
INSERT
INSERT
用法非常简单。现在我们有表students
如下。
列名 | 类型 | 约束 |
---|---|---|
id | int | primary key |
name | char(16) | NOT NULL |
向里面插入一条学号为1
,姓名为学姐
的学生,只需要写如下SQL
语句。
INSERT INTO students VALUES (1, '学姐');
语法
INSERT INTO [表] VALUES (列值1,列值2,...);
其中INSERT
语句有一个简单的变体,能比较明确地指明将值交付给哪个列。
INSERT INTO students (id, name) VALUES (1, '学妹');
这样写相当于指明了1
应该是id
,'学妹'
应该是name
。
插入多条也很简单,只要在VALUES
后面跟更多小括号包围的值集合就行了,记得拿括号分隔,下面给个例子。
INSERT INTO students (id, name)
VALUES (1, '学渣'), (2, '学霸'), (3, '学神');
INSERT SELECT
这个写法比较有意思,从一个表查询出数据,并插入另一个表。
举个例子来说,我们有两个班级表,分别叫学渣班
和补习班
,一旦学渣成绩烂到一定程度,那么我们就要把他分配到补习班里去强制补习。
怎么做呢?看下面啦。
INSERT INTO 补习班(name,score)
SELECT 学渣班.name, 学渣班.score
FROM 学渣班
WHERE 学渣班.score < 10;
值得注意的是,INSERT
填充补习班表时用的并不是你SELECT
的列名,而是SELECT
后列名的顺序,来对应到要INSERT
的表的列上。
其他的写法和SELECT
相同。
修改
UPDATE
UPDATE
语句的作用是修改现存行的数据,非常值得注意的是用UPDATE
语句时一定要小心写WHERE
子句,不然就等着删库跑路吧。
依然举个实际栗子,学号为10
的学生成绩由于作弊而被取消了,我们要更新他的成绩为 0 分,这真是个悲伤的故事:P
UPDATE students SET score = 0 WHERE id = 10;
语法是这样的。
UPDATE [表名] SET [列名] = [新值] WHERE [条件];
更新多条的话是这样的
UPDATE [表名]
SET [列1] = [新值],
[列2] = [新值],
...
[列N] = [新值]
WHERE [条件];
千万小心,如果没有
WHERE
子句的话,指定的列会全部被设置成这个值。这样一来,所有的学生都变成了 0 分......你会被手撕了的。
删除
DELETE
DELETE
的作用是删除行,同样的,万分注意WHERE
子句一定要正确编写,不然真的要删库跑路了。
同样以之前那位作弊的同学为例,很遗憾,他又一次作弊被抓住了,传说中的高科技 AR 技术作弊眼镜也没能让他逃过监考员的火眼金睛,于是他被退学了......
另一个悲伤的故事:P
DELETE FROM students WHERE id = 10;
语法是这样子的。
DELETE FROM [表名] WHERE [条件];
如果不写WHERE
的话......找个好点的新工作吧,不要再去写SQL
了,ORM 多好。
注意,不写
WHERE
子句会删除这个表里的所有行。