MySQL从删库到跑路(六)——SQL插入、更新、删除操作
作者:天山老妖S
链接:http://blog.51cto.com/9291927
一、插入数据
1、为表的所有字段插入数据
使用基本的INSERT语句插入数据要求指定表名称和插入到新记录的值。
INSERT INTO table_name (column_list) VALUES (value_list);
insert into `TSubject` (subjectID,subjectName,BookName,Publisher) values ('0004','英语','大学英语走遍美国','清华出版社')
可以不指定插入的列
insert into `TSubject` values ('0005','高等数学','高等数学教材','清华出版社')
2、为表的指定字段插入数据
为表的指定字段插入数据,就是在INSERT语句中只向部分字段中插入值,而其他字段的值为表定义时的默认值。必须制定插入的列
insert into TSubject (subjectID,subjectName) values ('0006','高等数学2')
insert into TSubject (subjectName,subjectID) values ('数据结构','0007')
3、同时插入多条记录
INSERT语句可以同时向数据表中插入多条记录,插入时指定多个值列表,每个值列表之间用逗号分隔开,基本语法如下:
INSERT INTO table_name (column_list)
VALUES (value_list1), (value_list2),...,
(value_listn);
示例:
insert into TSubject (subjectName,subjectID) values ('C#开发','0008'),('苹果开发','0009')
4、将查询结果插入到表中
INSERT语句和SELECT语句组成的组合语句即可快速地从一个或多个表中向一个表中插入多个行。
INSERT INTO table_name1 (column_list1) SELECT (column_list2) FROM table_name2 WHERE (condition)
示例:
insert into ST (subectid,subjectName) select subjectid,subjectName from TSubject where `Publisher` is not null
二、更新数据
1、根据本表的条件更改记录
MySQL中使用UPDATE语句更新表中的记录,可以更新特定的行或者同时更新所有的行
UPDATE table_name
SET column_name1 = value1,
column_name2=value2,……,
column_namen=valuen WHERE (condition);
示例:
update `TStudent` set sname=concat(sname,'net') where class='net'update `TStudent` set sname=left(sname,3) where class='net'
根据学生的生日 在学生的姓名后标记 1988年大一 1987年大二 1986年大三 1985年大四
update TStudent set sname=CONCAT(sname,case year(birthday)%5
when 0 then '大四' when 1 then '大三' when 2 then '大二' else '大一' end) where year(birthday)>=1985 and year(birthday)<=1988
2、根据另一张表的条件更改记录
UPDATE table_nameA a join table_nameB b on a. column_name1=b. column_name1
SET a.column_name1 = value1,
a.column_name2=value2,……,
a.column_namen=valuen
WHERE b. column_name2>20
实例:将有不及格的学生姓名后加*标记
update TStudent a join TScore b on a.`StudentID`=b.`StudentID`set a.`Sname`=concat(sname,'*') where b.mark<60
同时更改两张表的列
实例:把分数低于60分的学生,加5分,并在学生姓名添加标记+
update TStudent a join TScore b on a.`StudentID`=b.`StudentID`set a.`Sname`=concat(sname,'+'), b.mark=b.`mark`+5
where b.mark<60;
子查询也能实现相同功能
以下语句将分数有大于98分的学生姓名后加#号标记
update TStudent set Sname=concat(sname,'#') where studentid in(select studentid from TScore where mark>98);
三、删除数据
1、根据本表的条件删除记录
从数据库中删除数据使用DELETE语句,DELETE语句允许WHERE子句指定删除条件。
DELETE FROM table_name [WHERE condition>]
删除学号小于00010的学生
delete from TStudent where studentid< '00010'
2、根据另一张表的条件删除记录
DELETE a FROM table_a a join table_b b on a.column1 = b.column1 [WHERE condition>]
删除分数小于60分的学生
delete a from TStudent a join TScore b on a.`StudentID` = b.`StudentID` where b.mark<60
也可以使用子查询实现。
删除分数表中分数大于90的学生
delete from TStudent where studentid in (select studentid from TScore where mark>90)
喜欢的小伙伴们可以搜索我们个人的微信公众号“程序员的成长之路”点击关注或扫描下方二维码

MySQL从删库到跑路(六)——SQL插入、更新、删除操作的更多相关文章
- MySQL从删库到跑路(三)——SQL语言
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.SQL语言简介 1.SQL语言简介 SQL是结构化查询语言(Structured Query Language) ...
- MySQL从删库到跑路_高级(五)——触发器
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.触发器简介 1.触发器简介 触发器是和表关联的特殊的存储过程,可以再插入,删除或修改表中的数据时触发执行,比数据 ...
- MySQL从删库到跑路_高级(六)——索引
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.索引简介 1.索引简介 索引(Index)是帮助MySQL高效获取数据的数据结构. 在MySQL中,索引属于存储 ...
- MySQL从删库到跑路_高级(七)——事务和锁
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.事务简介 1.事务简介 事务(Transaction)是指作为单个逻辑工作单元执行的一系列操作. 2.事物的特效 ...
- MySQL从删库到跑路(五)——SQL查询
作者:天山老妖S 链接:http://blog.51cto.com/9291927 1.查询所有字段 在SELECT语句中使用星号“”通配符查询所有字段在SELECT语句中指定所有字段select f ...
- MySQL从删库到跑路(一)——MySQL数据库简介
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.MySQL简介 1.MySQL简介 MySQL是一个轻量级关系型数据库管理系统,由瑞典MySQL AB公司开发, ...
- MySQL从删库到跑路_高级(四)——存储过程
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.存储过程简介 1.存储过程简介 存储过程是一组具有特定功能的SQl语句集组成的可编程的函数,经编译创建并保存在数 ...
- MySQL从删库到跑路_高级(二)——自定义函数
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.自定义函数简介 自定义函数(user-defined function UDF)是一种对MySQL扩展的途径,其 ...
- MySQL从删库到跑路_高级(一)——数据完整性
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.数据完整性简介 1.数据完整性简介 数据冗余是指数据库中存在一些重复的数据,数据完整性是指数据库中的数据能够正确 ...
随机推荐
- 【转】失效迭代器(Invalidating Iterators)
当一个容器变化时,指向该容器中元素的迭代器可能失效.这使得在迭代器变化期间改变容器容易出现问题.在这方面,不同的容器提供不同的保障:vectors: 引起内存重新分配的插入运算使所有迭代器失效,插 ...
- 编译安装的gitlab8.x如何修改时区设置
编译安装的gitlab 8.x版本默认的时区是UTC,在页面上显示的时间默认是零时区的区时,安装完成之后,如果页面上显示的时间比北京时间少了8个小时,则需要修改一下时区 把gitlab.yml文件中的 ...
- Ios8 Xcode6 设置Launch Image 启动图片
http://blog.sina.com.cn/s/blog_6c97abf10102voui.html Http://Www.woowen.com/Swift/2014/12/12/Ios8设置La ...
- CodeFrist、ModelFirst、DatabaseFirst
一.CodeFirst 使用System.Data.Entity.DbContext与System.Data.Entity.DbSet构建的数据模型,没有可视化文件但只有实体类的称为CodeFirst ...
- Node.js 命令行程序开发资料
Node.js 命令行程序开发教程http://www.ruanyifeng.com/blog/2015/05/command-line-with-node.html用Node.js创建命令行工具ht ...
- yii---where该如何使用
简单示例yii 的where使用方法: $where = ['post_id'=>$postId]; //$list = ForumThreadPost::find()->where($w ...
- Django---路由如何配置
具体配置在项目配置文件夹下的 urls.py: from index import views urlpatterns = [ path('admin/', admin.site.urls), pat ...
- OpenCV Save CvRect to File 保存CvRect变量到文件
在OpenCv中,我们有时候需要查看CvRect变量的值,我们可以通过将其保存到文件来查看,保存的代码如下: void writeCvRectToFile(CvRect &rect, cons ...
- bootstrap中点击左边展开
<div id="sideNav" href=""><i class="material-icons dp48 glyphicon- ...
- Python面向对象之属性
属性的定义和调用 1,定义时,在普通方法的基础上添加@property装饰器 2,定义时,属性仅有一个self参数 3,调用时,无需括号 vim day7-8.py #!/usr/bin/python ...