MySQL数据库锁机制的相关原理简介(2)

来源:asp之家 时间:2010-04-22 15:34:00 


下面描述了一些方法来避免或减少表锁定造成的竞争:

· 试图使 SELECT 语句运行得更快。可能必须创建一些摘要(summary)表做到这点。

· 用--low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的第2个SELECT语句将在UPDATE语句前执行,而不需要等候第1个 SELECT 完成。

· 可以使用SET LOW_PRIORITY_UPDATES=1语句指定具体连接中的所有更新应使用低优先级。

· 可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。

· 可以用HIGH_PRIORITY属性给与一个特定的SELECT语句较高优先级。

· 为max_write_lock_count系统变量指定一个低值来启动mysqld来强制MySQL在具体数量的插入完成后临时提高所有等待一个表的SELECT 语句的优先级。这样允许在一定数量的WRITE锁定后给出READ锁定。

· 如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。

· 如果你对同一个表混合插入和删除,INSERT DELAYED将会有很大的帮助。

· 如果你对同一个表混合使用 SELECT 和DELETE 语句出现问题,DELETE 的LIMIT 选项可以有所帮助。

· 对 SELECT 语句使用SQL_BUFFER_RESULT可以帮助使表锁定时间变短。

· 可以更改mysys/thr_lock.c中的锁代码以使用单一的队列。在这种情况下,写锁定和读锁定将具有相同的优先级,对一些应用程序会有帮助。

这里是一些MySQL中表锁定相关的技巧:

· 如果不混合更新与需要在同一个表中检查许多行的选择,可以进行并行操作。

· 可以使用 LOCK TABLES 来提高速度,因为在一个锁定中进行许多更新比没有锁定的更新要快得多。将表中的内容切分为几个表也可以有所帮助。

· 如果在MySQL中表锁定时遇到速度问题,可以将表转换为 InnoDB 或BDB 表来提高性能。


标签:MySQL,数据库锁,MySQL锁死
0
投稿

猜你喜欢

  • SQL语句优化提高数据库性能

    2024-01-29 03:40:08
  • 仿淘宝首页商品分类列表效果

    2009-01-22 13:39:00
  • Python3对称加密算法AES、DES3实例详解

    2022-08-16 19:52:56
  • Python中常用的内置方法

    2023-06-29 00:25:32
  • 第五章之BootStrap 栅格系统

    2024-05-05 09:14:46
  • Django视图函数的具体使用

    2023-07-25 11:02:54
  • mysql分表分库的应用场景和设计方式

    2024-01-22 05:49:39
  • SQL Server误区30日谈 第12天 TempDB的文件数和需要和CPU数目保持一致

    2024-01-21 19:07:29
  • Python实现多条件筛选目标数据功能【测试可用】

    2023-07-17 21:03:46
  • 微信小程序实现签字功能

    2024-04-16 09:26:12
  • git-pycharm配置.ignore文件的详细过程

    2023-04-18 23:05:57
  • 使用python opencv对目录下图片进行去重的方法

    2023-07-06 20:04:13
  • 由prototype_1.3.1进入javascript殿堂-类的初探

    2008-05-22 12:44:00
  • python中的json模块常用方法汇总

    2022-02-27 01:35:09
  • Centos7系统下Mysql主从同步配置方案

    2024-01-24 11:29:18
  • Python判断以什么结尾以什么开头的实例

    2021-07-31 06:42:58
  • Python网络编程中urllib2模块的用法总结

    2022-05-26 18:49:53
  • php引用传值实例详解学习

    2023-11-15 06:11:30
  • Python实现多线程爬表情包详解

    2022-05-26 01:30:55
  • PHP数据类型之布尔型的介绍

    2023-11-14 21:56:00
  • asp之家 网络编程 m.aspxhome.com