MySQL(九)插入、更新和删除
常用的SQL语句,除了select用于查询,还有insert、update、delete等。
一、insert
insert:用来插入(或添加)行到数据库中,常见方式有以下几种:
①插入完整的行;
②插入行的一部分;
③插入多行;
④插入某些查询的结果;
1、插入完整的行
例如:insert into usertable
values(null,
'zhangsan',
'25',
'1992-05-20',
null,
null);
这条SQL语句插入一条新的个人信息到usertable表,存储在每个表列中的数据在values中给出,对每个列必须提供一个值,如果某个列没有值,应使用null(假定表允许对该项指定空值);
各个列必须以它们在表定义中出现的次序填充;缺点在于;高度依赖表中列的定义次序,如果表结构出现变动,难免出现问题。
更安全的方法如下(相对比较麻烦):
例如:insert into usertable(user_id,
user_name,
user_year,
user_birthday,
user_address,
user_email)
values(null,
'zhangsan',
'25',
'1992-05-20',
null,
null);
这条SQL语句与上面的SQL语句完成同样的工作,但给出了列名,valuse必须以指定的次序匹配指定的列名,不一定按照列出现在表中的实际次序;优点是:即使表结构改变,此insert语句仍然正确工作。
insert使用注意事项:
①无论使用哪种insert语法,都必须给出values的正确数目,如果不提供列名,则必须给每个表列提供一个值;如果提供列名,则必须对每个列出的列给出一个值;
②如果表定义允许,则可以在insert操作中省略某些列,列必须满足这两个条件(1.改列定义为允许null值;2.在表定义中给出默认值【如果不给出值,则使用默认值】);
③数据库被多个用户访问,一般检索是最重要的,可以通过在insert和into中间添加关键字low priority,指示MySQL降低insert语句的优先级(同样适用于update和delete语句);
2、插入多个行
例如:insert into usertable(user_id,
user_name,
user_year,
user_birthday,
user_address,
user_email)
values(null,
'zhangsan',
'25',
'1992-05-20',
null,
null);
或者只要每条insert语句中的列名(和次序)相同,可以只在insert语句后面输入一次列名就可以(单个insert语句由多组值,每组值用一堆圆括号包含,用逗号隔开)
PS:MYSQL用单条insert语句处理多个插入比使用多个insert语句快。
3、插入检索出的数据
例如:insert into usertable(user_id,
user_name,
user_year,
user_birthday,
user_address,
user_email)
select user_id,
user_name,
user_year,
user_birthday,
user_adress,
user_email
from newtablebase;
这条SQL语句中,select从newtablebase表中检索出要插入的数据,select列出的每个列对应tablebase表名后所跟的列表中的每个列。
PS:insert select语句中,不一定要求列名匹配,实际上select中的第一列将用来填充表列中指定的第一列;insert select语句中select语句可包含where子句过滤插入的数据。
二、更新数据
如果要更新(修改)表中的数据,可以使用update语句,有以下两种方法:
①更新表中特定行;
②更新表中所有行;
update语句由三部分构成:
①要更新的表;
②列名和它们的新值;
③确定要更新行的过滤条件;
例如:update usertable
set user_email = '3033310371@qq.com'
where user_id = '10086';
这条SQL语句中,要更新的表名为usertable,set命令用来将新值赋给被更新的列user_email;
PS:update语句总是以要更新的表的名字开始,以where子句结束,它告诉MySQL更新哪一行。
更新多个列:update usertable
set user_name = 'zhangsan',
user_email = '3033310371@qq.com'
where user_id = '10086';
更新多个列时,只需要使用单个set命令,每个“列=值”对之间用逗号分隔(最后一列不用逗号)。
PS:如果用update更新多个行,且更新中一行或多行出现错误,则update操作将被取消(错误发生前执行的动作将被回滚到最初状态。即已更新的被恢复原来的值);
如果希望出错误,更新继续执行,可以使用ignore关键字:update ignore tablebase......
如果希望删除一个值,可以将它设置为null(如果表定义允许null值),例子如下:
update usertable
set user_email = null
where user_id = '10086';
三、删除数据
从一个表汇总删除数据,使用delete语句;有以下两种方式:
①从表中删除特定行;
②从表中删除所有行;
例如:delete from usertable where user_id = '10086';
这条SQL语句中,delete from要求指定从中删除数据的表名,where子句过滤要删除的行。
PS:delete不需要列名或者通配符,delete删除整行而不是整列,为了删除指定的列,可使用update语句(delete从表中删除行甚至表中所有行,但不删除表本身);
如果想删除表中所有行,可使用truncate table语句,它的执行效率比delete更快(truncate实际上是删除原来表并重新新建一个表,而不是逐行删除表中数据)。
更新和删除规则:
①除非确实打算更新或删除每一行,否则决不能使用不带where子句的update或delete语句;
②保证每个表都有主键,尽可能像where子句那样使用;
③对update和delete语句使用where子句前,最好先select进行测试,保证过滤的数据是正确的;
④使用强制实施引用完整性的数据库(这样MySQL将不允许删除具有与其他表相关联的数据的行)。
MySQL(九)插入、更新和删除的更多相关文章
- SQL.Cookbook 读书笔记4 插入更新和删除
		
第四章 插入更新和删除 4.1 插入数据 ,'PROGRA','NEW YOURK'); 4.2 从一个表向另一个表中复制 insert into dept_east(deptno,dname,loc ...
 - MySQL<添加、更新与删除数据>
		
添加.更新与删除数据 添加数据 为表中所有字段添加数据 INSERT INTO 表名(字段名1,字段名2,……) VALUES(值1,值2,……); insert into 表名 values(值1, ...
 - mySQL 插入,更新和删除数据
		
插入数据: 语法: INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN ); 如 ...
 - mySQL 教程 第5章 插入 更新与删除数据
		
使用SQL Manager管理工具连接到schoolDB.由于三张表都设置了主键,因此,以下练习中插入的记录,主键不能重. 插入数据 1. 练习:为表的所有字段插入数据 为表中所有字段插入数据,可以不 ...
 - MySQL入门很简单:  9  插入 更新与删除数据
		
1. 插入数据:INSERT 1)为表的所有字段插入数据 第一种: 不指定具体的字段名 INSERT INTO 表名 VALUES(值1,值2,...,值n): 第二种:INSERT语句中列出所有字段 ...
 - MySQL笔记(三)之数据插入更新与删除
		
INSERT INTO INSERT INTO 语句用于向表格中插入新的行. 语法: INSERT INTO 表 VALUES (值1, 值2,....) # 列数必须和值的个数匹配 INSERT I ...
 - MySQL datetime的更新,删除网上的一些老概念
		
网上的老概念 第一点:是以前的MySQL的datetime的最小值是:'1000-01-01 00:00:00'(貌似),但是最新的MySQL测试datetime的最小值可以是:'0000-00-00 ...
 - Mysql高效插入/更新数据
		
从tushare抓取到的财务数据,最开始只是想存下来,用的办法想简单点,是:插入--报错-update 但发现这个方法太蠢,异常会导致大量无效连接,改为: for idx,row in d2.iter ...
 - mysql批量插入更新操作
		
//添加关联赠品(确定) public function addGiveGoods($ids,$child,$parent_sku_no){ $license=new LicenseModel(); ...
 
随机推荐
- Breeze 部署 Kubernetes 1.12.1高可用集群
			
今天看文章介绍了一个开源部署 K8S 的工具,有空研究下~ Github 地址: https://github.com/wise2c-devops/breeze
 - hdu-3790 最短路径问题(双重权值)
			
Problem Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的. Input ...
 - JavaScript 频繁发射事件处理的优化 --- 函数节流/事件稀释
			
引子:昨天面试时面试官问了如何实现一个固定导航栏,在我答完后面试官问我可能存在哪些问题,如何优化? 这个问题我答得不太好,但现在回想起来应该有两个问题: 1. 把 fixbar元素 position: ...
 - mock数据的基础使用
			
一.应用场景 在我们自己做一个项目时,会遇到后端还没完成数据输出或者接口没写好的情况.你没有办法想后台获取数据,这时候需要前端只好自己写静态模拟数据(假数据).mockjs就是用来创造假数据的,他的用 ...
 - 【代码笔记】iOS-tableView滑动的范围函数
			
//tableview滑动的范围 -(void)scrollViewDidScroll:(UIScrollView *)scrollView { myTableView.contentSize = C ...
 - JS性能优化 之 事件委托
			
面试中2次被问到过这个知识点,实际开发中,应用事件委托也比较常见.JS中事件委托的实现主要依赖于 事件冒泡 .那什么是事件冒泡?就是事件从最深的节点开始,然后逐步向上传播事件,举个例子:页面上有这么一 ...
 - 惊闻企业Web应用生成平台 活字格 V4.0 免费了,不单可视化设计器免费,服务器也免费!
			
官网消息: 针对活字格开发者,新版本完全免费!您可下载活字格 Web 应用生成平台 V4.0 Updated 1,方便的创建各类 Web 应用系统,任意部署,永不过期. 我之前学习过活字格,也曾经向用 ...
 - OneAPM大讲堂 | 基于图像质量分析的摄像头监控系统的实现
			
今天咱们要介绍的技术很简单,请看场景: 你在家里安装了几个摄像头想监视你家喵星人的一举一动,然而,就在喵星人准备对你的新包发动攻击的时候,图像突然模糊了.毕竟图像模糊了以后你就没法截图回家和喵当面对质 ...
 - JMeter—断言(十一)
			
参考<全栈性能测试修炼宝典JMeter实战>第六章 JMeter 元件详解中第六节断言断言用来对服务器的响应数据做验证,常用的断言是响应断言,支持正则表达式. 一.BeanShell As ...
 - 简单易懂的程序语言入门小册子(3):基于文本替换的解释器,let表达式,布尔类型,if表达式
			
let表达式 let表达式用来声明一个变量. 比如我们正在写一个模拟掷骰子游戏的程序. 一个骰子有6个面. 所以这个程序多次用到了6这个数字. 有一天,我们忽然改变主意,要玩12个面的骰子. 于是我们 ...