mysql数据库应用从入门到精通?MySQL从入门到精通(九) MySQL锁,各种锁
很多朋友对于mysql数据库应用从入门到精通和MySQL从入门到精通(九) MySQL锁,各种锁不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
我要学习数据库请推荐点入门书或者视频更好了
学哪一个数据库并不重要,关键是你要选择了一个,然后学深入一些,
我的建议是学Oracle,因为它与Java的结合很紧密.
oracle9i的下载地址:
http://download.oracle.com/otn/nt/oracle9i/9201/92010NT_Disk1.zip
http://download.oracle.com/otn/nt/oracle9i/9201/92010NT_Disk2.zip
http://download.oracle.com/otn/nt/oracle9i/9201/92010NT_Disk3.zip
这个是要三张盘的,你可以试试这个下载地址,我是在四月份的时候下载过,现在不知道还有没有效了.
安装Oracle总报错,这是初学时最头痛的问题,但我希望你能自己找到解决办法(发贴问或自己搜),只要是能解决,这就是你以后的财富.
到于用到的书,
入门的书随便找一本就可以,无非是介绍SQL的标准,和数据库通用的SELECT,INSER,UPDATE,DELETE语句,和Oracle一些常用的函数.
如果你只是做程序开发,知道这些,可以应付一些普通问题了,时间长了,学会写复杂SQL时,就可以处理更难的业务问题了,
但Oracle最强的地方在于数据库的管理,如何合理的定制数据库,数据库备份,数据安全,OracleDBA,这些才是Oracle值得称道的地方,
如果你有心成为DBA的话,应该注意这些,关于这方面我就不能给你提供帮助了,因为我达不到这个层次,这方面要是能够看到一本好书,如果<java编程思想>那样的好书,那真是收益非同小可.
只能帮你这么多了
MySQL从入门到精通(九) MySQL锁,各种锁
锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,除传统的计算资源(CPU、RAM、I/O)争用外,数据也是一种供许多用户共享的资源,如何保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素,从这个角度来说,锁对数据库而言是尤其重要,也更加复杂。MySQL中的锁,按照锁的粒度分为:1、全局锁,就锁定数据库中的所有表。2、表级锁,每次操作锁住整张表。3、行级锁,每次操作锁住对应的行数据。
全局锁就是对整个数据库实例加锁,加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将阻塞。其典型的使用场景就是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性。但是对数据库加全局锁是有弊端的,如在主库上备份,那么在备份期间都不能执行更新,业务会受影响,第二如果是在从库上备份,那么在备份期间从库不能执行主库同步过来的二进制日志,会导致主从延迟。
解决办法是在innodb引擎中,备份时加上--single-transaction参数来完成不加锁的一致性数据备份。
添加全局锁: flush tables with read lock;解锁 unlock tables。
表级锁,每次操作会锁住整张表.锁定粒度大,发送锁冲突的概率最高,并发读最低,应用在myisam、innodb、BOB等存储引擎中。表级锁分为:表锁、元数据锁(meta data lock, MDL)和意向锁。
表锁又分为:表共享读锁 read lock、表独占写锁write lock
语法: 1、加锁 lock tables表名... read/write
2、释放锁 unlock tables或者关闭客户端连接
注意:读锁不会阻塞其它客户端的读,但是会阻塞其它客户端的写,写锁既会阻塞其它客户端的读,又会阻塞其它客户端的写。大家可以拿一张表来测试看看。
元数据锁,在加锁过程中是系统自动控制的,无需显示使用,在访问一张表的时候会自动加上,MDL锁主要作用是维护表元数据的数据一致性,在表上有活动事务的时候,不可以对元数据进行写入操作。为了避免DML和DDL冲突,保证读写的正确性。
在MySQL5.5中引入了MDL,当对一张表进行增删改查的时候,加MDL读锁(共享);当对表结构进行变更操作时,加MDL写锁(排他).
查看元数据锁:
select object_type,object_schema,object_name,lock_type,lock_duration from performance_schema_metadata_locks;
意向锁,为了避免DML在执行时,加的行锁与表锁的冲突,在innodb中引入了意向锁,使得表锁不用检查每行数据是否加锁,使用意向锁来减少表锁的检查。意向锁分为,意向共享锁is由语句select... lock in share mode添加。意向排他锁ix,由insert,update,delete,select。。。for update添加。
select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_lock;
行级锁,每次操作锁住对应的行数据,锁定粒度最小,发生锁冲突的概率最高,并发读最高,应用在innodb存储引擎中。
innodb的数据是基于索引组织的,行锁是通过对索引上的索引项加锁来实现的,而不是对记录加的锁,对于行级锁,主要分为以下三类:
1、行锁或者叫record lock记录锁,锁定单个行记录的锁,防止其他事物对次行进行update和delete操作,在RC,RR隔离级别下都支持。
2、间隙锁Gap lock,锁定索引记录间隙(不含该记录),确保索引记录间隙不变,防止其他事物在这个间隙进行insert操作,产生幻读,在RR隔离级别下都支持。
3、临键锁Next-key-lock,行锁和间隙锁组合,同时锁住数据,并锁住数据前面的间隙Gap,在RR隔离级别下支持。
innodb实现了以下两种类型的行锁
1、共享锁 S:允许一个事务去读一行,阻止其他事务获得相同数据集的排他锁。
2、排他锁 X:允许获取排他锁的事务更新数据,阻止其他事务获得相同数据集的共享锁和排他锁。
insert语句排他锁自动添加的
update语句排他锁自动添加
delete语句排他锁自动添加
select正常查询语句不加锁。。。
select。。。lock in share mode共享锁需要手动在select之后加lock in share mode
select。。。for update排他锁需要手动在select之后添加for update
默认情况下,innodb在repeatable read事务隔离级别运行,innodb使用next-key锁进行搜索和索引扫描,以防止幻读。
间隙锁唯一目的是防止其它事务插入间隙,间隙锁可以共存,一个事务采用的间隙锁不会阻止另一个事务在同一间隙上采用的间隙锁。
有数据库基础,如何快速精通mysql
本周内容:455字
阅读时间:3~5分钟
前言
MySQL是一款免费开源、小型、关系型数据库管理系统。随着该数据库功能不断完善、性能的不断提高,可靠性不断增强。它虽然是免费,但与其他商业数据库一样,具有数据库系统的通用性,提供了数据库的存取、增加、修改、删除或更加复杂的操作。同时MySQL所使用的 SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL作为网站数据库。
下面开始介绍搭建的过程
一、准备环境
系统:
Centos 6.5_64
二、安装过程
1.yum-y install mysql-server
2.设置服务开机启动
3.启动数据库服务
4.设置MySQLroot用户
5.设置root用户密码为
6.登录数据库
7.创建数据库test1
8.建立数据库表格,xm姓名,xb性别,csny出生年龄
9增加数据库条目记录,姓名:李一,性别:男年龄:1988.9.01
书籍推荐
《MySQL 5.7从入门到精通》
本书主要包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与恢复、日志以及性能优化等。最后通过两个综合案例的数据库设计,进一步讲述MySQL在实际工作中的应用。
本书注重实战操作,帮助读者循序渐进地掌握MySQL中的各项技术。本书共有480个实例和14个综合案例,还有大量的经典习题。下载文件中赠送了近20小时培训班形式的视频教学录像,详细讲解了书中每一个知识点和每一个数据库操作的方法和技巧。同时下载文件中还提供了本书所有例子的源代码,读者可以直接查看和调用。
本书适合MySQL数据库初学者、MySQL数据库开发人员和MySQL数据库管理员,同时也能作为高等院校相关专业师生的教学用书。
让阅读成为习惯
好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!