MySQL 24小时入门笔记(3),插入和删除,删库到跑路

MySQL 24小时入门笔记

插入

INSERT

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 SELECT

这个写法比较有意思,从一个表查询出数据,并插入另外一个表。技术

举个例子来讲,咱们有两个班级表,分别叫学渣班补习班,一旦学渣成绩烂到必定程度,那么咱们就要把他分配到补习班里去强制补习。数据

怎么作呢?看下面啦。查询

INSERT INTO 补习班(name,score) 
	SELECT 学渣班.name, 学渣班.score 
    FROM 学渣班 
    	WHERE 学渣班.score < 10;

值得注意的是,INSERT 填充补习班表时用的并非你SELECT的列名,而是SELECT后列名的顺序,来对应到要INSERT的表的列上。tab

其余的写法和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子句会删除这个表里的全部行。

相关文章
相关标签/搜索