- 浏览: 3319162 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (567)
- Web前端-html/表单 (19)
- Web前端-CSS (24)
- Web前端-CSS框架 (4)
- Web前端-JS语言核心 (50)
- Web前端-JS客户端 (26)
- nodejs生态+grunt (10)
- seajs和requirejs (9)
- backbone等框架 (7)
- 模板基础 (7)
- Web前端-deps(不改动) (6)
- Web前端-component (10)
- Web前端-jquery-plugin (13)
- 浏览器兼容性 (6)
- Web前端-使用jQuery (25)
- Web前端-使用jqueryui (6)
- Web前端-性能优化 (3)
- Web协议-HTTP (6)
- ExtJS (13)
- PHP (22)
- PHP面向对象 (4)
- PHP扩展-SOAP (6)
- PHP扩展-curl (4)
- PHP与HTML(导出) (5)
- PHP扩展-综合 (7)
- mysql基础应用 (18)
- 技术心情 (18)
- 算法和面试题 (17)
- 工具(开发)使用 (36)
- memcached原理 (2)
- session和cookie (4)
- UML (2)
- Web前端_FusionCharts (5)
- Web前端_Flex (4)
- Web前端_JSP (3)
- JavaSE (10)
- JavaEE (4)
- tomcat (2)
- Servlet开发 (3)
- Spring开发 (1)
- REST相关 (2)
- 大访问量、高并发 (2)
- 网络编程 (1)
- YII (21)
- linux命令和内核 (12)
- yii与数据库 (10)
- yii与表单 (12)
- yii view层 (1)
- perl (7)
- yii扩展 (7)
- shell (4)
- photoshop (7)
- 视觉设计 (2)
- 我关注的名人在路上 (4)
- 1-自学能力 (1)
- 2-人际沟通能力 (3)
- 3-职业规划能力 (7)
- 4-项目管理能力 (2)
- python (3)
- django (4)
- Mysql高级应用 (6)
- prototype.js (4)
- Web系统安全 (1)
- Web前端-mobile (2)
- egret (6)
- jQuery源码分析 (5)
- fis (4)
最新评论
-
yzq21056563:
感谢作者分享~请教下,http://www.lisa33xia ...
CSS基础:text-overflow:ellipsis溢出文本 -
u012206458:
$.ajax的error,complete,success方法 -
DEMONU:
谢谢,虽然不能给你赞助,但是要给你顶
mysql中key 、primary key 、unique key 与index区别 -
njupt_tolmes:
阿凡达阿凡达阿凡达阿凡达阿凡达阿凡达阿凡达阿凡达阿凡达阿滕庆亚 ...
CSS基础:text-overflow:ellipsis溢出文本 -
zenmshuo:
用过SpreadJS,也包含数据可视化的图表
推荐几个web中常用js图表插件
mysql insert时几个操作DELAYED 、IGNORE、ON DUPLICATE KEY UPDATE的区别
zccst整理
一、DELAYED的使用
使用延迟插入操作
DELAYED调节符应用于INSERT和REPLACE语句。当DELAYED插入操作到达的时候,服务器把数据行放入一个队列中,并立即给客户端返回一个状态信息,这样客户端就可以在数据表被真正地插入记录之前继续进行操作了。如果读取者从该数据表中读取数据,队列中的数据就会被保持着,直到没有读取者为止。接着服务器开始插入延迟数据行(delayed-row)队列中的数据行。在插入操作的同时,服务器还要检查是否有新的读取请求到达和等待。如果有,延迟数据行队列就被挂起,允许读取者继续操作。当没有读取者的时候,服务器再次开始插入延迟的数据行。这个过程一直进行,直到队列空了为止。
几点要注意事项:
· INSERT DELAYED应该仅用于指定值清单的INSERT语句。服务器忽略用于INSERT DELAYED...SELECT语句的DELAYED。
· 服务器忽略用于INSERT DELAYED...ON DUPLICATE UPDATE语句的DELAYED。
· 因为在行被插入前,语句立刻返回,所以您不能使用LAST_INSERT_ID()来获取AUTO_INCREMENT值。AUTO_INCREMENT值可能由语句生成。
· 对于SELECT语句,DELAYED行不可见,直到这些行确实被插入了为止。
· DELAYED在从属复制服务器中被忽略了,因为DELAYED不会在从属服务器中产生与主服务器不一样的数据。
注意,目前在队列中的各行只保存在存储器中,直到它们被插入到表中为止。这意味着,如果您强行中止了mysqld(例如,使用kill -9)或者如果mysqld意外停止,则所有没有被写入磁盘的行都会丢失。
二、IGNORE的使用
IGNORE是MySQL相对于标准SQL的扩展。如果在新表中有重复关键字,或者当STRICT模式启动后出现警告,则使用IGNORE控制ALTER TABLE的运行。如果没有指定IGNORE,当重复关键字错误发生时,复制操作被放弃,返回前一步骤。如果指定了IGNORE,则对于有重复关键字的行,只使用第一行,其它有冲突的行被删除。并且,对错误值进行修正,使之尽量接近正确值。
insert ignore into tb(...) value(...)
这样不用校验是否存在了,有则忽略,无则添加
三、ON DUPLICATE KEY UPDATE的使用
MySQL 自4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE语法,使得原本需要执行3条SQL语句(SELECT,INSERT,UPDATE),缩减为1条语句即可完成。
例如ipstats表结构如下:
引用
CREATE TABLE ipstats (
ip VARCHAR(15) NOT NULL UNIQUE,
clicks SMALLINT(5) UNSIGNED NOT NULL DEFAULT '0'
);
原本需要执行3条SQL语句,如下:
IF (SELECT * FROM ipstats WHERE ip='192.168.0.1') {
UPDATE ipstats SET clicks=clicks+1 WHERE ip='192.168.0.1';
} else {
INSERT INTO ipstats (ip, clicks) VALUES ('192.168.0.1', 1);
}
而现在只需下面1条SQL语句即可完成:
INSERT INTO ipstats VALUES('192.168.0.1', 1) ON DUPLICATE KEY UPDATE clicks=clicks+1;
注意,要使用这条语句,前提条件是这个表必须有一个唯一索引或主键。
mysql> create table i (id int unique, co int);
mysql> insert into i values (1,1),(2,1);
mysql> insert into i values (1,1) on duplicate key update co=co+1;
mysql> select * from i;
+------+------+
| id | co |
+------+------+
| 1 | 2 |
| 2 | 1 |
+------+------+
//如果再执行一次insert into i values (1,1) on duplicate key update co=co+1;则结果为:
mysql> select * from i;
+------+------+
| id | co |
+------+------+
| 1 | 3 |
| 2 | 1 |
+------+------+
//经测试,id为主键时也可行,与unique时一样
create table i (id int auto_increment primary key, co int);
四、三者之间区别
DELAYED 做为快速插入,并不是很关心失效性,提高插入性能。
ignore 只关注主键对应记录是不存在,无则添加,有则忽略。
ON DUPLICATE KEY UPDATE 在添加时操作,关注非主键列,注意与ignore的区别。有则更新指定列,无则添加。
zccst整理
一、DELAYED的使用
使用延迟插入操作
DELAYED调节符应用于INSERT和REPLACE语句。当DELAYED插入操作到达的时候,服务器把数据行放入一个队列中,并立即给客户端返回一个状态信息,这样客户端就可以在数据表被真正地插入记录之前继续进行操作了。如果读取者从该数据表中读取数据,队列中的数据就会被保持着,直到没有读取者为止。接着服务器开始插入延迟数据行(delayed-row)队列中的数据行。在插入操作的同时,服务器还要检查是否有新的读取请求到达和等待。如果有,延迟数据行队列就被挂起,允许读取者继续操作。当没有读取者的时候,服务器再次开始插入延迟的数据行。这个过程一直进行,直到队列空了为止。
几点要注意事项:
· INSERT DELAYED应该仅用于指定值清单的INSERT语句。服务器忽略用于INSERT DELAYED...SELECT语句的DELAYED。
· 服务器忽略用于INSERT DELAYED...ON DUPLICATE UPDATE语句的DELAYED。
· 因为在行被插入前,语句立刻返回,所以您不能使用LAST_INSERT_ID()来获取AUTO_INCREMENT值。AUTO_INCREMENT值可能由语句生成。
· 对于SELECT语句,DELAYED行不可见,直到这些行确实被插入了为止。
· DELAYED在从属复制服务器中被忽略了,因为DELAYED不会在从属服务器中产生与主服务器不一样的数据。
注意,目前在队列中的各行只保存在存储器中,直到它们被插入到表中为止。这意味着,如果您强行中止了mysqld(例如,使用kill -9)或者如果mysqld意外停止,则所有没有被写入磁盘的行都会丢失。
二、IGNORE的使用
IGNORE是MySQL相对于标准SQL的扩展。如果在新表中有重复关键字,或者当STRICT模式启动后出现警告,则使用IGNORE控制ALTER TABLE的运行。如果没有指定IGNORE,当重复关键字错误发生时,复制操作被放弃,返回前一步骤。如果指定了IGNORE,则对于有重复关键字的行,只使用第一行,其它有冲突的行被删除。并且,对错误值进行修正,使之尽量接近正确值。
insert ignore into tb(...) value(...)
这样不用校验是否存在了,有则忽略,无则添加
三、ON DUPLICATE KEY UPDATE的使用
MySQL 自4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE语法,使得原本需要执行3条SQL语句(SELECT,INSERT,UPDATE),缩减为1条语句即可完成。
例如ipstats表结构如下:
引用
CREATE TABLE ipstats (
ip VARCHAR(15) NOT NULL UNIQUE,
clicks SMALLINT(5) UNSIGNED NOT NULL DEFAULT '0'
);
原本需要执行3条SQL语句,如下:
IF (SELECT * FROM ipstats WHERE ip='192.168.0.1') {
UPDATE ipstats SET clicks=clicks+1 WHERE ip='192.168.0.1';
} else {
INSERT INTO ipstats (ip, clicks) VALUES ('192.168.0.1', 1);
}
而现在只需下面1条SQL语句即可完成:
INSERT INTO ipstats VALUES('192.168.0.1', 1) ON DUPLICATE KEY UPDATE clicks=clicks+1;
注意,要使用这条语句,前提条件是这个表必须有一个唯一索引或主键。
mysql> create table i (id int unique, co int);
mysql> insert into i values (1,1),(2,1);
mysql> insert into i values (1,1) on duplicate key update co=co+1;
mysql> select * from i;
+------+------+
| id | co |
+------+------+
| 1 | 2 |
| 2 | 1 |
+------+------+
//如果再执行一次insert into i values (1,1) on duplicate key update co=co+1;则结果为:
mysql> select * from i;
+------+------+
| id | co |
+------+------+
| 1 | 3 |
| 2 | 1 |
+------+------+
//经测试,id为主键时也可行,与unique时一样
create table i (id int auto_increment primary key, co int);
四、三者之间区别
DELAYED 做为快速插入,并不是很关心失效性,提高插入性能。
ignore 只关注主键对应记录是不存在,无则添加,有则忽略。
ON DUPLICATE KEY UPDATE 在添加时操作,关注非主键列,注意与ignore的区别。有则更新指定列,无则添加。
发表评论
-
MySQL创建用户与授权
2013-08-29 21:43 1240zccst转载 一, 创建用户: 命令:CR ... -
mysql导入/导出命令
2013-05-15 15:52 1098作者:zccst 最常用: 导出数据库为文件 mysqld ... -
运行中的mysql状态查看
2013-02-22 14:19 1677zccst整理 对正在运行的 ... -
mysql导出的几种办法
2012-12-24 16:29 7685作者:zccst 一、使用mysqldump导出 my ... -
强大的alter
2012-11-14 22:28 1257作者:zccst alter的主要作用是修改已经建立的表结构。 ... -
mysql replace into用法详细说明
2012-10-23 17:42 1776zccst转载 mysql replace into ... -
mysql中key 、primary key 、unique key 与index区别
2012-10-12 12:15 262372作者:zccst 一、key与pri ... -
mysql日期相关函数
2012-06-15 15:27 1723作者:zccst 日期函数 date_format(crea ... -
mysql安全之sql注入
2012-04-28 18:42 1167zccst整理 如何避免? 1,使用mysql_escap ... -
MySQL索引类型一览 让MySQL高效运行起来
2012-04-27 15:29 1176zccst转载 批注:学习mysql那么久,今天终于有点更上 ... -
mysql 多表连接 left join 等
2012-04-14 23:34 34485作者:zccst 一、 理论 ... -
mysql 删除全部表
2012-02-27 16:25 26071作者:zccst 方式一:手工方式 1,直接操作数据库 先 ... -
MySQL 数据类型 详解
2012-01-18 15:28 1367zccst整理 批注:mysql数据类型分为4类,与C语言教 ... -
mysql函数初步
2011-12-12 17:50 1091一、日期函数 日期函数较多 比如对timestamp求月份,可 ... -
mysql警告和错误解决办法集合
2011-10-31 11:33 1232一、在创建mysql时,查看警告详情 在create语句执行之 ... -
数据库关于group by 两个或以上条件的分析
2011-08-25 12:58 59031首先group by 的简单说明: group by 一 ... -
mysql常用命令
2011-06-07 12:09 1242作者:zccst 2014-05-18 创建新表各类型模板 ...
相关推荐
MySQL中的`INSERT`语句是用于向数据库表中插入新数据的命令,它有多种变体,包括`DELAYED`, `IGNORE`, 和 `ON DUPLICATE KEY UPDATE`。这些选项提供了不同的处理策略,以适应不同场景的需求。 1. **DELAYED**: `...
ON DUPLICATE KEY UPDATE` 和 `REPLACE INTO` 是MySQL中处理批量插入并更新已有数据的两种有效策略,它们提供了在保持数据完整性和性能之间平衡的解决方案。根据具体业务需求和数据约束,选择合适的方法来优化数据...
`ON DUPLICATE KEY UPDATE`则是在遇到重复键时进行更新的操作。 #### 三、关键字解析 - **LOW_PRIORITY**: 低优先级,当使用此选项时,服务器将等待所有读取操作完成后再执行插入操作。 - **DELAYED**: 延迟插入,...
但如果使用IGNORE选项,MySQL将自动忽略该错误并可能执行其他操作,具体取决于ON DUPLICATE KEY UPDATE子句。 9. **多行INSERT语句**: 通过在VALUES列表中包含多个值对,可以同时插入多行数据。例如,`INSERT ...
以下的文章主要介绍的是MySQL INSERT INTO语句的实际用法以及MySQL INSERT INTO语句中的相关语句的介绍,MySQL INSERT INTO语句在实际应用中是经常使用到的语句,所以对其相关的内容还是多多掌握为好。 INSERT [LOW...
MySQL中的`ON DUPLICATE KEY UPDATE`语句是一个非常实用的功能,它允许你在插入新记录时检查是否存在相同的记录。如果存在,那么就更新已有记录;如果不存在,就插入新的记录。这个特性在处理配置文件或者需要确保...
使用`ON DUPLICATE KEY UPDATE`可以在插入时遇到主键冲突时更新已有记录。 3. **DELETE语句**:用于删除表中的记录。例如,删除部门ID为1001的记录: ```sql DELETE FROM department WHERE department_id=1001; ...
ON DUPLICATE KEY UPDATE` 语句,这可以提供更好的性能,并且在某些情况下功能更加灵活。 ### 结论 通过以上介绍可以看出,`REPLACE INTO` 是 MySQL 中一种非常有用的特性,它可以在插入新记录的同时自动处理重复...
在SQL语句中,`REPLACE INTO` 和 `INSERT INTO` 都是用来向数据库表中添加数据的命令,但它们之间存在重要的区别。本文将详细阐述这两种操作的区别以及使用场景。 首先,`INSERT INTO` 是最常用的插入数据的方式。...
不过,需要注意的是,`DELAYED`不适用于INSERT...SELECT和ON DUPLICATE KEY UPDATE语句,并且在从属复制服务器上不会启用。 使用`LAST_INSERT_ID()`获取自增ID时,不适用于`INSERT DELAYED`,因为插入操作不是立即...
1. `ON DUPLICATE KEY UPDATE`:在INSERT语句中,如果插入的记录违反了唯一索引,此选项允许你更新已经存在的记录,而不是抛出错误。 2. `DELAYED`:在INSERT语句中,这个选项告诉MySQL在事务提交后再插入数据,这...
例如,监控CPU使用率,确保在插入操作时CPU没有超过70%的负载。 10. MySQL服务器的I/O优化: - 在MySQL服务器配置中可以优化I/O,如调整`innodb_flush_log_at_trx_commit`参数,以及设置`innodb_flush_method`参数...
标题中的“rabbitmq_delayed_3.6.x延迟插件.rar”表明这是一个关于RabbitMQ的3.6.x版本的延迟消息插件。RabbitMQ是业界广泛使用的开源消息代理和队列服务器,它允许应用程序之间进行异步通信。延迟队列在某些场景下...
**RabbitMQ消息插件:rabbitmq_delayed_message_exchange 3.7** RabbitMQ是一个开源的消息代理和队列服务器,广泛应用于分布式系统中的异步处理、任务队列和消息路由。在某些场景下,我们需要将消息延迟发送,例如...