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