1. 事务处理和并发性
1.1. 基础知识和相关概念
1)全部的表类型都可以使用锁,但是只有InnoDB和BDB才有内置的事务功能。
2)使用begin开始事务,使用commit结束事务,中间可以使用rollback回滚事务。
3)在默认情况下,InnoDB表支持一致读。
SQL标准中定义了4个隔离级别:read uncommited,read commited,repeatable read,serializable。
read uncommited即脏读,一个事务修改了一行,另一个事务也可以读到该行。
如果第一个事务执行了回滚,那么第二个事务读取的就是从来没有正式出现过的值。?
read commited即一致读,试图通过只读取提交的值的方式来解决脏读的问题,
但是这又引起了不可重复读取的问题。
一个事务执行一个查询,读取了大量的数据行。在它结束读取之前,另一个事务可能完成了对数据行的更改。当第一个事务试图再次执行同一个查询,服务器就会返回不同的结果。
repeatable read即可重复读,在一个事务对数据行执行读取或写入操作时锁定了这些数据行。
但是这种方式又引发了幻想读的问题。
因为只能锁定读取或写入的行,不能阻止另一个事务插入数据,后期执行同样的查询会产生更多的结果。
serializable模式中,事务被强制为依次执行。这是SQL标准建议的默认行为。
4)如果多个事务更新了同一行,就可以通过回滚其中一个事务来解除死锁。
5)MySQL允许利用set transaction来设置隔离级别。
6)事务只用于insert和update语句来更新数据表,不能用于对表结构的更改。执行一条更改表结构或begin则会立即提交当前的事务。
7)所有表类型都支持表级锁,但是MyISAM只支持表级锁。
8)有两种类型的表级锁:读锁和写锁。
读锁是共享锁,支持并发读,写操作被锁。
写锁是独占锁,上锁期间其他线程不能读表或写表。
8)如果要支持并发读写,建议采用InnoDB表,因为它是采用行级锁,可以获得更多的更新性能。
9)很多时候,可以通过经验来评估什么样的锁对应用程序更合适,不过通常很难说一个锁比别的更好,这全都要依据应用程序来决定,不同的地方可能需要不同的锁。当前MySQL已经支持 ISAM, MyISAM, MEMORY (HEAP) 类型表的表级锁了,BDB 表支持页级锁,InnoDB 表支持行级锁。
10)MySQL的表级锁都是写锁优先,而且是采用排队机制,这样不会出现死锁的情况。对于 InnoDB 和 BDB 存储引擎来说,是可能产生死锁的。这是因为 InnoDB 会自动捕获行锁,BDB 会在执行 SQL 语句时捕获页锁的,而不是在事务的开始就这么做。
1.2. 不同锁的优缺点及选择
行级锁的优点及选择:
1)在很多线程请求不同记录时减少冲突锁。
2)事务回滚时减少改变数据。
3)使长时间对单独的一行记录加锁成为可能。
行级锁的缺点:
1)比页级锁和表级锁消耗更多的内存。
2)当在大量表中使用时,比页级锁和表级锁更慢,因为他需要请求更多的所资源。
3)当需要频繁对大部分数据做 GROUP BY 操作或者需要频繁扫描整个表时,就明显的比其它锁更糟糕。
4)使用更高层的锁的话,就能更方便的支持各种不同的类型应用程序,因为这种锁的开销比行级锁小多了。
5)可以用应用程序级锁来代替行级锁,例如MySQL中的 GET_LOCK() 和 RELEASE_LOCK()。但它们是劝告锁(原文:These are advisory locks),因此只能用于安全可信的应用程序中。
6)对于 InnoDB 和 BDB 表,MySQL只有在指定用 LOCK TABLES 锁表时才使用表级锁。在这两种表中,建议最好不要使用 LOCK TABLES,因为 InnoDB 自动采用行级锁,BDB 用页级锁来保证事务的隔离。
表锁的优点及选择:
1)很多操作都是读表。
2)在严格条件的索引上读取和更新,当更新或者删除可以用单独的索引来读取得到时:UPDATE tbl_name SET column=value WHERE unique_key_col=key_value;DELETE FROM tbl_name WHERE unique_key_col=key_value;
3)SELECT 和 INSERT 语句并发的执行,但是只有很少的 UPDATE 和 DELETE 语句。
4)很多的扫描表和对全表的 GROUP BY 操作,但是没有任何写表。
表锁的缺点:
1)一个客户端提交了一个需要长时间运行的 SELECT 操作。
2)其他客户端对同一个表提交了 UPDATE 操作,这个客户端就要等到 SELECT 完成了才能开始执行。
3)其他客户端也对同一个表提交了 SELECT 请求。由于 UPDATE的优先级高于 SELECT,所以 SELECT 就会先等到 UPDATE 完成了之后才开始执行,它也在等待第一个 SELECT操作。
1.3. 如何避免锁的资源竞争
1)让 SELECT 速度尽量快,这可能需要创建一些摘要表。
2)启动 mysqld 时使用参数 --low-priority-updates。这就会让更新操作的优先级低于 SELECT。
这种情况下,在上面的假设中,第二个 SELECT 就会在 INSERT 之前执行了,而且也无需等待第一个SELECT 了。
3)可以执行 SET LOW_PRIORITY_UPDATES=1 命令,指定所有的更新操作都放到一个指定的链接中去完成。
4)用 LOW_PRIORITY 属性来降低 INSERT,UPDATE,DELETE 的优先级。
5)用HIGH_PRIORITY 来提高 SELECT 语句的优先级。
6)从MySQL 3.23.7 开始,可以在启动 mysqld 时指定系统变量 max_write_lock_count 为一个比较低的值,它能强制临时地提高表的插入数达到一个特定值后的所有 SELECT 操作的优先级。它允许在 WRITE 锁达到一定数量后有 READ 锁。
7)当 INSERT 和 SELECT 一起使用出现问题时,可以转而采用 MyISAM 表,它支持并发的SELECT 和 INSERT 操作。
8)当在同一个表上同时有插入和删除操作时,INSERT DELAYED 可能会很有用。
9)当SELECT 和 DELETE 一起使用出现问题时,DELETE 的 LIMIT 参数可能会很有用。
10)执行SELECT 时使用 SQL_BUFFER_RESULT 有助于减短锁表的持续时间。
11)可以修改源代码 `mysys/thr_lock.c',只用一个所队列。这种情况下,写锁和读锁的优先级就一样了,这对一些应用可能有帮助。
分享到:
相关推荐
MySQL是目前流行和广泛使用的开源关系型数据库管理系统,它在性能上有着出色的表现,成为众多开发者和企业的首选。在MySQL数据库的使用过程中,有多个关键的知识点需要掌握,以保障数据库的高效稳定运行。 首先,...
《深入浅出 MySQL 数据库开发优化与管理维护》是一本专为MySQL爱好者和专业人士准备的指南,旨在帮助读者深入理解MySQL的各个方面,并提供实用的优化和管理策略。MySQL作为世界上最受欢迎的关系型数据库管理系统之一...
《深入浅出-MySQL数据库开发、优化与管理维护》是一本专为IT专业人士设计的全面指南,涵盖了MySQL数据库从基础到高级的各个方面。这本书旨在帮助读者深入理解MySQL的内部机制,提升开发效率,优化数据库性能,并掌握...
LabVIEW(Laboratory Virtual ...总之,“深入浅出LabVIEW数据库应用”涵盖了从基础到进阶的数据库操作技巧,通过学习和实践,开发者可以熟练地利用LabVIEW构建与数据库紧密集成的应用,满足各种数据处理需求。
分布式事务是数据库管理中的一个重要概念,它涉及到两个或多个网络主机的交互,这些主机提供了事务处理资源,而事务管理器负责创建和管理一个全局事务,该事务覆盖了对所有资源的操作。这种机制确保了在分布式环境下...
鲁班学院的这份课堂笔记深入浅出地探讨了MySQL中的核心概念:B+树索引、事务处理以及锁定机制。 一、InnoDB行格式、数据页结构以及索引底层原理分析 InnoDB是MySQL中最常用的存储引擎,它支持事务处理和行级锁定。...
作者夏昕,以其深入浅出的讲解风格,为读者揭示了Hibernate的内在原理和实际应用,帮助开发者更好地理解和使用这个强大的ORM(对象关系映射)工具。 一、Hibernate概述 Hibernate是一个开源的Java ORM框架,它简化...
《深入浅出Otter与Canal》是一本深入解析数据库同步工具Otter和Canal的专著,主要针对Java开发者。Otter和Canal都是在大数据处理领域中用于实时数据同步的重要工具,它们在分布式系统中的应用广泛,尤其是在日志传输...
本专题《深入浅出js(Node.js)异步流程控制》将探讨Node.js中的异步编程这一核心概念,帮助开发者更深入地理解和掌握这一技术。 异步编程是Node.js的核心特性之一,它允许程序在等待I/O操作完成时继续执行其他任务...
《深入浅出 SQL(中文版)》这本书是针对SQL语言的一本详解教程,特别以MySQL为例进行了深入的探讨。虽然书中的示例和讲解主要基于MySQL,但SQL作为一种通用的数据库查询语言,其核心概念和语法在Oracle、SQL Server等...
《深入浅出MySQL数据库开发、优化与管理维护》是一本专为MySQL爱好者和专业人士准备的指南,涵盖了数据库的开发、优化以及日常维护等关键领域。这本书以深入浅出的方式讲解了MySQL的核心概念和技术,旨在帮助读者...
MySQL 5.7.22开始支持write-set机制,分为COMMIT_ORDER、WRITESET和WRITESET_SESSION三种跟踪类型,分别对应不同的事务依赖策略和冲突检测算法。 在实现并行复制时,一个关键点是如何判断事务间是否存在锁冲突。...
总之,《深入浅出Hibernate》是学习和掌握Hibernate框架的宝贵资源,不仅涵盖了Hibernate的基础知识,还深入讲解了高级特性和最佳实践,为Java开发者提供了全面的Hibernate学习指南。通过阅读和实践书中的内容,...
### 深入浅出Hibernate #### ORM概念与原则 ORM(Object Relational Mapping,对象关系映射)是一种编程技术,用于将面向对象语言中的对象映射到关系型数据库中的记录上。它允许开发人员使用面向对象的方式进行...
《PHP5和MySQL从入门到精通》是一本深入浅出的编程教材,专注于PHP与MySQL的结合使用。这本书详尽地介绍了这两个强大的Web开发技术,旨在帮助初学者快速上手并逐渐成为专业人士。 PHP(Hypertext Preprocessor)是...
这本书深入浅出地介绍了MySQL的基本概念、安装配置、数据类型、表的创建与管理、SQL查询语言、索引、视图、存储过程、触发器、事务处理、备份与恢复等核心知识。通过跟随书中的"三思一步一步学"的方式,读者可以系统...
《深入浅出Hibernate》 Hibernate,作为Java领域中的一款流行持久化框架,是开发者们进行企业级应用开发的重要工具。它的出现,极大地简化了数据库与Java对象之间的交互,使得开发者可以更加专注于业务逻辑,而非...