今天研究了下insert delayed这个特性。
背景
RD反馈,他有一个异步的队列缓冲表,现在在做优化,看如果用insert delayed能不能提升性能?这个业务要求呢,本来就是异步插入到数据库的,所以并不是那么急着访问。听着,好像延迟插入也没什么不妥哈。
环境:mysql 5.6 innodb表
MySQL的这个特性只是听说过,没仔细研究过,趁这个机会研究下。
结论
首先查了下官网资料:
MySQL的这个特性,是MySQL对标准SQL的一个扩展,从MySQL 3.22.15 引入,5.6已经不推荐使用,5.7已经不支持了(虽然能识别,但是已经被忽略掉,而且会生成ER_WARN_LEGACY_SYNTAX_CONVERTED警告),在后续的版本中会废弃掉。
5.1:
mysql> show create table t2G
1. row **
Table: t2
Create Table: CREATE TABLE t2
(id
int(11) DEFAULT NULL,name
char(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
mysql> insert delayed into t2(id,name) values(1,'a');
ERROR 1616 (HY000): DELAYED option not supported for table ‘t2'
5.6:
mysql> show create table t1G
1. row **
Table: t1
Create Table: CREATE TABLE t1
(id
int(11) DEFAULT NULL,name
char(2) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
mysql> insert delayed into t1(id,name) values(1,'a');
Query OK, 1