手机
当前位置:查字典教程网 >编程开发 >mysql数据库 >MySql中使用INSERT INTO语句更新多条数据的例子
MySql中使用INSERT INTO语句更新多条数据的例子
摘要:我们知道当插入多条数据的时候insert支持多条语句:复制代码代码如下:INSERTINTOt_member(id,name,email)V...

我们知道当插入多条数据的时候insert支持多条语句:

复制代码 代码如下:

INSERT INTO t_member (id, name, email) VALUES

(1, 'nick', 'nick@126.com'),

(4, 'angel','angel@163.com'),

(7, 'brank','ba198@126.com');

但是对于更新记录,由于update语法不支持一次更新多条记录,只能一条一条执行:

复制代码 代码如下:

UPDATE t_member SET name='nick', email='nick@126.com' WHERE id=1;

UPDATE t_member SET name='angel', email='angel@163.com' WHERE id=4;

UPDATE t_member SET name='brank', email='ba198@126.com' WHERE id=7;

这里问题就出现了,倘若这个update list非常大时(譬如说5000条),这个执行率可想而知。

这就要介绍一下在MySql中INSERT语法具有一个条件DUPLICATE KEY UPDATE,这个语法和适合用在需要判断记录是否存在,不存在则插入存在则更新的记录。

具体的语法可以参见:http://dev.mysql.com/doc/refman/5.0/en/insert.html

基于上面这种情况,针对更新记录,仍然使用insert语句,不过限制主键重复时,更新字段。如下:

复制代码 代码如下:

INSERT INTO t_member (id, name, email) VALUES

(1, 'nick', 'nick@126.com'),

(4, 'angel','angel@163.com'),

(7, 'brank','ba198@126.com')

ON DUPLICATE KEY UPDATE name=VALUES(name), email=VALUES(email);

注意:ON DUPLICATE KEY UPDATE只是MySQL的特有语法,并不是SQL标准语法!

【MySql中使用INSERT INTO语句更新多条数据的例子】相关文章:

MySQL与MSSQl使用While语句循环生成测试数据的代码

mysql中关于时间的函数使用教程

MySQL一个索引最多有多少个列?真实的测试例子

mysql中提高Order by语句查询效率的两个思路分析

在MySQL中增添新用户权限的方法

在MySQL数据库中使用C执行SQL语句的方法

SQL Server中各种语句的完整语法

Navicat for MySQL 备份数据的操作如下

MySQL中几个常用的数据库操作函数

mysql中索引使用不当速度比没加索引还慢的测试

精品推荐
分类导航