数据库

 首页 > 数据库 > mariadb > 关于MySQL和MariaDB数据库中的的延时插入insert delayed

关于MySQL和MariaDB数据库中的的延时插入insert delayed

分享到:
【字体:
导读:
         摘要:语法:INSERTDELAYED...说明:INSERT语句的DELAYED选项是一个MySQL扩展标准的SQL,是非常有用的,如果你有客户,不用或不需要等待插入完成。这是一个常见的情况,当您使用MySQL用于日志记录和你还定期运行选择和更新语句,需要很长时间才能完成。当一个客...

关于MySQL和MariaDB数据库中的的延时插入insert delayed

语法

INSERT DELAYED ...

说明:

INSERT语句的DELAYED选项是一个MySQL扩展标准的SQL,是非常有用的,如果你有客户,不用或不需要等待插入完成。这是一个常见的情况,当您使用MySQL用于日志记录和你还定期运行选择和更新语句,需要很长时间才能完成。    

当一个客户使用插入延迟,它会在服务器立刻成功,当表没有被其他任何线程使用,被排队的行插入表。    

使用插入延迟另一个主要的好处是从许多客户插入捆绑在一起,以块方式写入。这是远远快于执行多次单独的插入。


注意, 如果表不在其他地方被使用,插入延迟比正常插入要慢。还有额外的开销,服务器对于每个有延迟行的表用一个单独的线程。这意味着只有当您真的确定你需要它,才使用插入延迟。    

排队的行仅保存在内存中,直到他们被插入到表。这意味着如果你强行终止mysqld (例如,使用kill - 9)或如果mysqld意外死亡,任何未被写入磁盘的排队行丢失。    

使用延迟有一些限制:
插入延迟只适用于MyISAM, MEMORY, ARCHIVE,BLACKHOLE (自从MySQL 5.1.19)表。参照MyISAM存储引擎,内存存储引擎,归档存储引擎,和Blackhole存储引擎。  
对MyISAM表,如果在数据文件中间没有空闲块, 支持并发的选择和插入语句的。在这些情况下,你很少对MyISAM需要使用插入延迟。  
插入延迟应该仅适用于INSERT语句中指定值列表。服务器对INSERT ... SELECT或INSERT ... ON DUPLICATE KEY UPDATE忽略了延迟插入。
因为插入延迟声明立即返回,在行被插入之前,您不能使用LAST_INSERT_ID()获得该语句可能产生AUTO_INCREMENT值。  
延迟行对SELECT语句是不可见,直到它们实际上已经被插入。  
延迟在复制从服务是忽略,以便在从服务插入延迟被当作一个正常的插入。这是因为延迟可能导致从服务和主服务有不同的数据。  
等待INSERT DELAYED语句被丢失,如果一个表被写锁和ALTER table用于修改表的结构。  
视图不支持插入延迟。  
不支持分区表插入延迟。

关于MySQL和MariaDB数据库中的的延时插入insert delayed
分享到:
关于MySQL/MariaDB数据库中的的cassandra...
关于MySQL/MariaDB数据库中的的cassandra存储引擎 Cassandra Storage Engine (SE) 运行直接通过 MariaDB/MySQL 来访问 Cassandra 数据库,并提供了 SQL 和 NoSQL 的数据集成。 当你需要: 直接通过 SQL 查询来获取 Cassandra 上的数据时 将数据插入到 Cassandra 时 使用 Cassandra SE 可以很方便处理,Cassandr...
MySQL vs MariaDB vs percona的tpcc性能...
MySQL vs MariaDB vs percona的tpcc性能测试结果 一、简述 是由原来 MySQL 的作者 Michael Widenius 创办的公司所开发的免费开源的数据库服务器。MariaDB基于事务的Maria存储引擎,替换了MySQL的MyISAM存储引擎,它使用了Percona的 XtraDB,InnoDB的变体。这个版本还包括了 PrimeBase XT (PBXT) 和 FederatedX ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……