MySQL事务、锁机制、查询缓存
MySQL事务
何为事务?
事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。
一个事务可以是一条SQL语句,一组SQL语句或整个程序。
事务的特性:
A:automicity
/*原子性:整个事务中的所有操作要么全部成功执行,要么全部失败回滚*/ C:consistency
/*一致性:事务必须是使数据库从一个一致性状态变到另一个一致性状态*/ I:isolation
/*隔离性:一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰*/ D:durability
/*持久性:事务一旦提交,其所做的修改会永久存入数据库中*/
事务的启动和结束
在MySQL中,事务开始使用COMMIT或ROLLBACK语句开始工作和结束。开始和结束语句的SQL命令之间形成了大量的事务。
这两个关键字“提交”和“回滚”主要用于MySQL的事务。
当一个成功的事务完成后,发出COMMIT命令应使所有参与表的更改才会生效。
如果发生故障时,应发出一个ROLLBACK命令返回的事务中引用的每一个表到以前的状态。
建议:在MySQL中有个服务器变量autocommit决定着事务的起止行为,系统默认是autocommit=ON;在实际生产环境中,应将此变量的状态设置为关闭,即需要时自己显式请求和提交事务最为合适。
事务支持SAVEPOINT
SAVEPOINT identifier //创建保存点
ROLLBACK TO [SAVEPOINT] identifier //回滚至某保存点
RELEASE SAVEPOINT identifier //释放保存点
事务的隔离级别
/*
READ-UNCOMMITTED (读未提交) -->导致脏读;
READ-COMMITTED (读提交) --> 不可重复读;
REPEATABLE-READ (可重复读) -->导致幻读;
SERIALIZABLE(可串行化)
*/
查看当前事务隔离级别的服务器变量:tx_isolation,默认是REPEATABLE-READ
事务日志的相关参数
innodb_log_file_size ####
innodb_log_files_in_group #
innodb_log_group_home_dir /
锁机制
主要是为了实现并发控制
锁粒度:
行级锁和表级锁
其类型有:
读锁:共享锁,可被其他用户进行读操作
写锁:独占锁
根据是否为用户手动请求,又分为:
显式锁:用户手动请求的锁
隐式锁:存储引擎自行根据需求施加的锁
显式锁使用方法:
/*施加锁*/
LOCK TABLES tbl_name [[AS] alias] lock_type [, tbl_name [[AS] alias] lock_type] ... lock_type:
READ [LOCAL] | [LOW_PRIORITY] WRITE /*解除锁*/
UNLOCK TABLES
MySQL的查询缓存
1.判断缓存是否命中根据:查询语句的哈希值判断;
哈希值考虑的因素有:
查询本身、要查询的数据库、客户端使用协议版本,。。。
2.哪些查询可能不会被缓存?
查询中包含UDF、存储函数、用户自定义变量、临时表、mysql库中的系统表、或者包含列级权限的表、有着不确定值的函数(Now());
3.查询缓存相关的服务器变量:
query_cache_min_res_unit //查询缓存中内存块的最小分配单位;
/*较小的值会减少浪费,但会导致更频繁的内存分配操作;
较大的值会造成浪费,也会导致碎片过多;
*/
query_cache_limit //能缓存的最大查询结果;对于有着较大结果的查询,建议在SELECT中使用SQL_NO_CACHE
query_cache_size //查询缓存总共可用的内存空间;单位是字节,必须是1024的整数倍;
query_cache_type //ON,OFF,DEMAND(除非SELECT语句中有SQL_CACHE,否则一律不缓存)
query_cache_wlock_invalidate //如果某表被其他的连接锁定,是否仍然可以从查询缓存中返回结果;默认为OFF,仍然可以返回结果;但有可能会改变服务器行为,ON则为禁止返回结果。
4.查询缓存状态相关的变量:

Qcache_inserts:可缓存查询语句的结果放入缓存中的次数
Qcache_not_cached:可缓存但未缓存的次数
缓存命中率评估:
Qcache_hits/(Qcache_hits+Com_select)
MySQL事务、锁机制、查询缓存的更多相关文章
- MySQL- 锁机制及MyISAM表锁
锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源(如CPU.RAM.I/O等)的争用以外,数据也是一种供许 多用户 共享的资源.如何保证数据并发访问的一致性.有效性是所 ...
- mysql insert锁机制【转】
最近再找一些MySQL锁表原因,整理出来一部分sql语句会锁表的,方便查阅,整理的不是很全,都是工作中碰到的,会持续更新 笔者能力有限,如果有不正确的,或者不到位的地方,还请大家指出来,方便你我,方便 ...
- 说一说MySQL的锁机制
锁概述 MySQL的锁机制,就是数据库为了保证数据的一致性而设计的面对并发场景的一种规则. 最显著的特点是不同的存储引擎支持不同的锁机制,InnoDB支持行锁和表锁,MyISAM支持表锁. 表锁就是把 ...
- 关于MySQL的锁机制详解
锁概述 MySQL的锁机制,就是数据库为了保证数据的一致性而设计的面对并发场景的一种规则. 最显著的特点是不同的存储引擎支持不同的锁机制,InnoDB支持行锁和表锁,MyISAM支持表锁. 表锁就是把 ...
- mysql 事务锁超时时间 innodb_lock_wait_timeout
mysql 事务锁超时时间 innodb_lock_wait_timeout: # 查询全局等待事务锁超时时间 SHOW GLOBAL VARIABLES LIKE 'innodb_lock_wait ...
- MySQL/MariaDB数据库的查询缓存优化
MySQL/MariaDB数据库的查询缓存优化 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL架构 Connectors(MySQL对外提供的交互接口,API): ...
- MySQL:锁机制和隔离事务级别
在mysql中的锁看起来是很复杂的,因为有一大堆的东西和名词:排它锁,共享锁,表锁,页锁,间隙锁,意向排它锁,意向共享锁,行锁,读锁,写锁,乐观锁,悲观锁,死锁.这些名词有的博客又直接写锁的英文的简写 ...
- 理解MySql事务隔离机制、锁以及各种锁协议
一直以来对数据库的事务隔离机制的理解总是停留在表面,其内容也是看一遍忘一边.这两天决定从原理上理解它,整理成自己的知识.查阅资料的过程中发现好多零碎的概念假设串起来足够写一本书,所以在这里给自己梳理一 ...
- MySQL 高级—— 锁机制
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 一.锁的概述 1.锁的定义 锁是计算机协调多个进程或线程并发访问某一资源的机制. 在数据库中,除传统的计 ...
- MySQL InnoDB锁机制
概述: 锁机制在程序中是最常用的机制之一,当一个程序需要多线程并行访问同一资源时,为了避免一致性问题,通常采用锁机制来处理.在数据库的操作中也有相同的问题,当两个线程同时对一条数据进行操作,为了保证数 ...
随机推荐
- mysql数据库字段bigint使用
Mysql里有个数据类型bigint 在java转换成实体对象时,处理不当容易出现以下异常: java.lang.ClassCastException: java.lang.Long cannot b ...
- spring:bean的作用范围和生命周期
bean的作用范围调整: <!--bean的作用范围调整 bean标签的scope属性: 作用:用于指定bean的作用范围 取值:常用的就是单例的和多例的 singleton:单例的(默认值) ...
- HTML-完美解决父子元素的外边距重叠和高度塌陷问题
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- openssl操作公私钥和加解密的一些常用命令
生成公私钥实践: 生成私钥,这里以椭圆曲线secp256k1为例: openssl ecparam -name secp256k1 -genkey -out secp256k1-priv.pem #带 ...
- 进程互斥软件实现之Dekker算法
一. 为什么需要互斥? 大多数系统允许多个进程共享资源(如CPU,IO设备,硬盘等), 为了保证进程间能够互不影响.安全正确地访问这些共享资源, 就必须对进程访问共享资源采取互斥控制. 进程互斥原则: ...
- jmeter参数化遇到的问题
遇到的问题是点击运行后,察看结果树没有任何结果,且右上角的警告日志是: meter.threads.JMeterThread: Test failed! java.lang.IllegalArgume ...
- differential related impedance and termination
Impedance (1) Z0 Z0 is the impedance of one T-line while other lines are held at 0. Single end. (2) ...
- thinkPHP 字段映射功能
thinkPHP的字段映射功能可以让你在表单中隐藏真正的数据表字段,而不用担心放弃自动创建表单对象的功能,假设我们的User表里面有username和email字段,我们需要映射成另外的字段,定义方式 ...
- PAT甲级——A1086 Tree Traversals Again
An inorder binary tree traversal can be implemented in a non-recursive way with a stack. For example ...
- quatz调度-手动终止线程(1) 创建触发器,线程执行完毕后添加到cleaner list
import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.SchedulerException;impor ...