MySQL 24小时入门笔记
插入
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子句会删除这个表里的所有行。