热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

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

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

语法

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用于修改表的结构。  
视图不支持插入延迟。  
不支持分区表插入延迟。


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
author-avatar
asfasfdsfd
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有