MYSQL面试题
MYSQL:(三种创建,四条语句,五种约束)
三种方法:MySQL创建用户的方法分成三种:INSERT USER表的方法、CREATE USER的方法、GRANT的方法
一、账号名称的构成方式
账号的组成方式:用户名+主机(所以可以出现重复的用户名,跟其他的[数据库](http://lib.csdn.net/base/mysql "MySQL知识库")不一样)
用户名:16字符以内.
主机名:可以用主机名和IP地址,也可以用通配符
通配符说明:172.18.10.%(IP地址为172.18.10段的所有IP地址都可以访问)
二、通过CREATE USER命令进行创建用户
脚本:CREATE USER 'username@host' [IDENTIFIED BY 'PASSWORD'] 其中密码是可选项;
例子:CREATE USER 'john@192.168.189.71' IDENTIFIED BY "123";
CREATE USER 'john@192.168.189.%' IDENTIFIED BY "123";
CREATE USER 'john@' ;
说明:该方法创建出来的用户只有连接数据库的权限,需要后续继续授权;
注意:用户与@后主机地址是一体的,用一个分号连接,否则会报错,ERROR 1396 (HY000): Operation CREATE USER failed for 'remote'@'%'
三、通过GRANT命令创建用户
当数据库存在用户的时候GRANT会对用户进行授权,但当数据库不存在该用户的时候,就会创建相应的用户并进行授权。(说明上面那步是多余的)
脚本:
GRANT <ALL|priv1,priv2,.....privn> ON
[object] [IDENTIFIED BY 'password']
[WITH GRANT OPTION];
MAX_QUERIES_PER_HOUR count
MAX_UPDATES_PER_HOUR count
MAX_CONNECTIONS_PER_HOUR count
MAX_USER_CONNECTIONS count
说明:priv代表权限select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14个权限
例子:mysql>grant select,insert,update,delete,create,drop on test.hr to john@192.168.10.1 identified by '123';
说明:给主机为192.168.10.1的用户john分配可对数据库test的hr表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123。
mysql>grant all privileges on test.* to joe@192.168.10.1 identified by '123';
说明:给主机为192.168.10.1的用户john分配可对数据库test所有表进行所有操作的权限,并设定口令为123。
mysql>grant all privileges on *.* to john@192.168.10.1 identified by '123';
说明:给主机为192.168.10.1的用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。
mysql>grant all privileges on *.* to john@localhost identified by '123';
说明:用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。
四条语句:增删改查
insert,delete,update,select
详细内容请看MYSQL基本操作语句
五种约束:
#五种完整性约束:
#NOT NULL :非空约束,指定某列不能为空;
#UNIQUE : 唯一约束,指定某列或者几列组合不能重复
#PRIMARY KEY :主键,指定该列的值可以唯一地标识该列记录
#FOREIGN KEY :外键,指定该行记录从属于主表中的一条记录,主要用于参照完整性
#CHECK :检查,指定一个布尔表达式,用于指定对应的值必须满足该表达式(mysql不支持check约束)
1、mysql有哪些常见的引擎,他们有什么区别?
ISAM MyISAM HEAP InnoDB 4种
a. ISAM:最老的引擎, 执行读取操作的速度很快,而且不占用大量的内存和存储资源。不足,它不支持事务处理,也不能够容错。
b. MyISAM:ISAM的mysql扩张, 继承了ISAM的优点,还增加了一些功能,如 索引,字段管理功能,表格锁定的机制等。并强调了快速读取操作,所以web开发大多数用此引擎。缺点和ISAM一样。而且为了优化多个并发的读写操作和锁定的机制,它必须经常运行OPTIMIZE TABLE命令,来恢复被更新机制所浪费的空间。
c. HEAP: 它允许只驻留在内存里的临时表格,驻留在内存里让HEAP要比ISAM和MYISAM都快,但是,它的表格存储在内存里,所以不及时保存的话,会造成数据丢失。
d. InnoDB, 支持事务处理(transaction process)和外来键。但是速度比前者慢,一般用于处理巨大数据量时的最大性能设计。
2、听说过mysql的锁吗?
锁(行锁、表锁、页锁、乐观锁、悲观锁等)
行锁 | 表锁 | 页锁 | |
---|---|---|---|
MyISAM | V | ||
BDB | V | V | |
InnoDB | V | V |
开销、加锁速度、死锁、粒度、并发性能
表锁:
开销小,加锁快;不会出现死锁;锁定力度大,发生锁冲突概率高,并发度最低
行锁:
开销大,加锁慢;会出现死锁;锁定粒度小,发生锁冲突的概率低,并发度高
页锁:
开销和加锁速度介于表锁和行锁之间;会出现死锁;锁定粒度介于表锁和行锁之间,并发度一般
悲观锁:在读取数据时锁住那几行,其他对这几行的更新需要等到悲观锁结束时才能继续
乐观锁:读取数据时不锁,更新时检查是否数据已经被更新过,如果是则取消当前更新
一般在悲观锁的等待时间过长而不能接受时我们才会选择乐观锁
从数据库sql语句角度看,悲观锁一般使用select * from table where condition for update,这个是进行一个强制锁记录的操作。而乐观锁一般是使用update table set xxx=xxx where condition and version=${version},一般通过版本号来限制需要更新的记录版本。
之前一直以为select ... for update的效率不高,其实这个和update是一样的,都会对符合where条件的记录加锁。mysql的锁分为三种,行级锁、区间锁、next-key锁,具体可以参考:http://dev.mysql.com/doc/refman/5.7/en/innodb-locking.html
所以可以知道,乐观锁的性能之所以比悲观锁好,原因不是因为sql语句的不同,而是因为加锁时间的不同。悲观锁认为记录被修改的冲突概率较大,所以在对记录操作前就将记录锁定,然后更新记录,最后提交,所以提交的成功率很高,但是造成的并发能力较低。而乐观锁认为修改记录的冲突概率很小,所以在更新记录之前不会锁记录,而是在最后提交的时候提交锁,这样锁定记录的时间较短,并发能力较高,但是冲突概率就提高了。乐观锁一般会使用一个版本号概念,目的是记录当前记录的版本,如果当前记录没有被修改,那么相应的版本就不会改变。在更新记录的时候通过版本号来限定更新记录的版本,起到防止并发更新的问题。
数据库中有记录,可以通过乐观锁或者悲观锁进行锁定记录。
乐观锁:update tablename set version=version+1 where key=${key} and version=${version},判断update结果影响的行数。将乐观锁放在一个事务中,通过行级锁进行控制。一个事务占用了行级锁,另一个事务无法获得锁,会产生两种情况,一种是等待锁超时,一种是版本变更,update失败。
如果没有记录,可以通过insert + 唯一索引的机制进行锁定,比较暴力,通过锁表
听说过事物吗?事物有哪些特性ACLD
一.什么是事务
事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。
事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交。如果其中一个步骤失败,将发生回滚操作,撤消撤消之前到事务开始时的所以操作。
二.事务的 ACID
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性
事 务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
3 、隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
数据库系统必须维护事务的以下特性 ( 简称 ACID) :
原子性 (Atomicity)
一致性 (Consistency)
隔离性 (Isolation)
持久性 (Durability)
原子性 (Atomicity)
事务中的所有操作要么全部执行,要么都不执行;
如果事务没有原子性的保证,那么在发生系统
故障的情况下,数据库就有可能处于不一致状
态。