MySQL 面试题

1、事务的基本特征

原子性(atomicity):一个事务必须视为一个不可分割的最小工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作,这就是事务的原子性。

一致性(consistency):数据库总数从一个一致性的状态转换到另一个一致性的状态。

隔离性(isolation):一个事务所做的修改在最终提交以前,对其他事务是不可见的。

持久性(durability):一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,修改的数据也不会丢失。

2、事务的隔离级别,mysql默认的隔离级别是什么?

读未提交(Read uncommitted),一个事务可以读取另一个未提交事务的数据,最低级别,任何情况都无法保证。

读已提交(Read committed),一个事务要等另一个事务提交后才能读取数据,可避免脏读的发生。

可重复读(Repeatable read),就是在开始读取数据(事务开启)时,不再允许修改操作,可避免脏读、不可重复读的发生。

串行(Serializable),是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。

Mysql的默认隔离级别是Repeatable read(可重复读)。

3、说一说脏读、不可重复读、幻读

脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据;

不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果因此本事务先后两次读到的数据结果会不一致;

幻读:幻读解决了不重复读,保证了同一个事务里,查询的结果都是事务开始时的状态(一致性);

4、数据表类型有哪些

答:MyIASMInnoDBHEAPISAMMERGEDBD以及Gemeni(一般只知道前两者即可)

5innodb引擎的4大特性

答:插入缓冲(insert buffer);二次写(double write);自适应哈希索引(ahi);预读(read ahead)

6InnoDB引擎的行锁是通过加在什么上实现的?

答:基于索引;

7Mysql中的myisaminnodb的区别,至少五点

InooDB支持事务,而MyISAM不支持事务;

InnoDB支持行级锁,而MyISAM支持表级锁;

InnoDB支持MVCC,而MyISAM不支持;

InnoDB支持外键,而MyISAM不支持;

InnoDB不支持全文索引,而MyISAM支持;

InnoDB不能通过直接拷贝表文件的方法拷贝表到另外一台机器, myisam 支持;

InnoDB表支持多种行格式, myisam 不支持;

InnoDB是索引组织表, myisam 是堆表;

8myisaminnodb select count(*)哪个更快,为什么

答:myisam更快,因为myisam内部维护了一个计数器,可以直接调取。

9、数据库三大范式

第一范式:数据库表中的字段都是单一属性的,不可再分(保持数据的原子性)

第二范式:第二范式必须符合第一范式,非主属性必须完全依赖于主键。

第三范式:在满足第二范式的基础上,在实体中不存在其他实体中的非主键属性,传递函数依赖于主键属性,确保数据表中的每一列数据都和主键直接相关,而不能间接相关(表中字段[非主键]不存在对主键的传递依赖)

10、说一说你能想到的sql语句优化,至少五种

1、避免select*,将需要查找的字段列出来;

2、使用连接(join)来代替子查询;拆分大的deleteinsert语句;

3、使用limit对查询结果的记录进行限定;

4、用 exists 代替 in 是一个好的选择;

5、用Where子句替换HAVING 子句 因为HAVING 只会在检索出所有记录之后才对结果集进行过滤;

6、不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引;

7、尽量避免在where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描;

8、尽量避免在 where 子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描;

9、尽量避免在 where 子句中使用!=<>操作符,否则将引擎放弃使用索引而进行全表扫描;

11、说一说你能想到的表结构优化,至少五种

永远为每张表设置一个ID (所有建表的时候不设置主键的程序猿都应该被辞退)

选择正确的存储引擎 ;使用可存下数据的最小的数据类型,整型 < date,time < char,varchar < blob

使用简单的数据类型,整型比字符处理开销更小,因为字符串的比较更复杂。如,int类型存储时间类型,bigint类型转ip函数;

使用合理的字段属性长度,固定长度的表会更快;

使用enumchar而不是varchar

尽可能使用not null定义字段(给空字段设置默认值)

尽量少用text;给频繁使用和查询的字段建立合适的索引;

12、说几个mysql中你常用的函数

答:sumcount avgminmax

13、说几个你除了增删改查之外在mysql中常用的命令

答:Explaindescribeshowtruncate

14、说几个除了增删改查之外常用的关键字

distinctlimitoffsetorder byunionunion allbetweengroup by

15unionunion all的区别

对重复结果的处理:UNION在进行表链接后会筛选掉重复的记录,Union All不会去除重复记录;

对排序的处理:Union将会按照字段的顺序进行排序;UNION ALL只是简单的将两个结果合并后就返回;从效率上说,UNION ALL 要比UNION快很多。

16varchar(100)varchar(200)的区别

答:varchar(100)最多存放100个字符,varchar(200)最多存放200个字符,varchar(100)(200)存储hello所占空间一样,但后者在排序时会消耗更多内存,因为order by col采用fixed_length计算col长度(memory引擎也一样)

17varchar(20)int(20)中的20含义一样吗

答:不一样,前者表示最多存放20个字符,后者表示最多显示20个字符,但是存储空间还是占4字节存储,存储范围不变;

18、什么是存储过程?用什么来调用?

答:存储过程是一个预编译的SQL 语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL ,使用存储过程比单纯SQL 语句执行要快。可以用一个命令对象来调用存储过程。

19、什么是触发器?触发器的作用?

答:触发器是一中特殊的存储过程,主要是通过事件来触发而被执行的。它可以强化约束,来维护数据的完整性和一致性,可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以联级运算。如,某表上的触发器上包含对另一个表的数据操作,而该操作又会导致该表触发器被触发。

20、存储过程与触发器的区别

答:触发器与存储过程非常相似,触发器也是SQL语句集,两者唯一的区别是触发器不能用EXECUTE语句调用,而是在用户执行Transact-SQL语句时自动触发(激活)执行。触发器是在一个修改了指定表中的数据时执行的存储过程。通常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性和一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业务规则,以确保数据的完整性。触发器不同于存储过程,触发器主要是通过事件执行触发而被执行的,而存储过程可以通过存储过程名称名字而直接调用。当对某一表进行诸如UPDATEINSERTDELETE这些操作时,SQL SERVER就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合这些SQL语句所定义的规则。

21、索引的作用?和它的优点缺点是什么?

答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。

22MySQL主要的索引类型

普通索引:是最基本的索引,它没有任何限制;

唯一索引:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一;

主键索引:是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值;

组合索引:指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。使用组合索引时遵循最左前缀集合;

全文索引:主要用来查找文本中的关键字,而不是直接与索引中的值相比较,mysqlMyISAM支持全文索引而InnoDB不支持;

23、使用like 'a%' like'%a'like'%a%'查询时是否会使用索引

答:'a%'会,其他两个不会;

24、使用索引注意事项

索引不会包含有NULL的列,复合索引中只要有一列含有NULL值,那么这一列对于此符合索引就是无效的;

使用短索引,对串列进行索引,如果可以就应该指定一个前缀长度;

短索引不仅可以提高查询速度而且可以节省磁盘空间和I/O操作;

mysql查询只使用一个索引,因此数据库默认排序可以符合要求的情况下不要使用排序操作,尽量不要包含多个列的排序,如果需要最好给这些列建复合索引;注意like,上文已经提到;

不要在列上进行运算;

不使用NOT IN <>、!=操作,但<,<==>,>=,BETWEEN,IN是可以用到索引的;

索引要建立在经常进行select操作的字段上;

索引要建立在值比较唯一的字段上;对于那些定义为textimagebit数据类型的列不应该增加索引;

wherejoin中出现的列需要建立索引;

如果where字句的查询条件里使用了函数(如:where DAY(column)=…),mysql将无法使用索引;

join操作中(需要从多个数据表提取数据时)mysql只有在主键和外键的数据类型相同时才能使用索引,否则及时建立了索引也不会使用;

25、说一说什么是外键,优缺点

答:外键指的是外键约束,目的是保持数据一致性,完整性,控制存储在外键表中的数据。使两张表形成关联,外键只能引用外表中列的值;

优点:由数据库自身保证数据一致性,完整性,更可靠,因为程序很难100%保证数据的完整性,而用外键即使在数据库服务器当机或者出现其他问题的时候,也能够最大限度的保证数据的一致性和完整性。有主外键的数据库设计可以增加ER图的可读性,这点在数据库设计时非常重要。外键在一定程度上说明的业务逻辑,会使设计周到具体全面。

缺点:可以用触发器或应用程序保证数据的完整性;过分强调或者说使用外键会平添开发难度,导致表过多,更改业务困难,扩展困难等问题;不用外键时数据管理简单,操作方便,性能高(导入导出等操作,在insert, update, delete 数据的时候更快);

26、在什么时候你会选择使用外键,为什么

答:在我的业务逻辑非常简单,业务一旦确定不会轻易更改,表结构简单,业务量小的时候我会选择使用外键。因为当不符合以上条件的时候,外键会影响业务的扩展和修改,当数据量庞大时,会严重影响增删改查的效率。

27、什么叫视图?游标是什么?

视图是一种虚拟的表,具有和物理表相同的功能;可以对视图进行增,改,查,操作,视图通常是有一个表或者多个表的行或列的子集。对视图的修改不影响基本表。它使得我们获取数据更容易,相比多表查询。

游标:是对查询出来的结果集作为一个单元来有效的处理。游标可以定在该单元中的特定行,从结果集的当前行检索一行或多行。可以对结果集当前行做修改。一般不使用游标,但是需要逐条处理数据的时候,游标显得十分重要。

28mysql有没有rowid

答:没有,InnoDB如果没有定义主键,内部会生成一个主键编号rowid ,但是无法查询到。在平时InnoDB建表的时候我们最好自己确定主键,防止每次插入数据前数据库会去生成rowid

29mysql怎么在查询时给查出来的数据设置一个自增的序号?

set @i=0;SELECT (@i:=@i+1) 别名 FROM table, (SELECT @i:=0) AS 别名 ;

 30、主键、外键和索引的区别?

定义: 

  • 主键唯一标识一条记录,不能有重复的,不允许为空 
  • 外键表的外键是另一表的主键, 外键可以有重复的, 可以是空值 
  • 索引该字段没有重复值,但可以有一个空值

作用:

  • 主键用来保证数据完整性
  • 外键用来和其他表建立联系用的
  • 索引是提高查询排序的速度

个数:

  • 主键主键只能有一个
  • 外键一个表可以有多个外键
  • 索引一个表可以有多个唯一索引

 31charvarchar的区别?

答:是一种固定长度的类型,varchar则是一种可变长度的类型,它们的区别是:  

char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于MMySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).  

varchar适用场景:

  1. 字符串列得最大长度比平均长度大很多
  2. 字符串很少被更新,容易产生存储碎片
  3. 使用多字节字符集存储字符串

Char得场景:

存储具有近似得长度(md5,身份证,手机号),长度比较短小得字符串(因为varchar需要额外空间记录字符串长度),更适合经常更新得字符串,更新时不会出现页分裂得情况,避免出现存储碎片,获得更好的io性能

 32SQL语言包括哪几部分?每部分都有哪些操作关键字?

答:SQL语言包括数据定义(DDL)、数据操纵(DML),数据控制(DCL)和数据查询(DQL四个部分。

数据定义:Create Table,Alter Table,Drop Table, Craete/Drop Index;

数据操纵:Select ,insert,update,delete;

数据控制:grant,revoke

数据查询:select

33Myql中的事务回滚机制概述

事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位;

事务回滚是指将该事务已经完成的对数据库的更新操作撤销。

要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态,而第一个表已经被修改完毕。而当你把它们设定为一个事务的时候,当第一个表修改完,第二表修改出现异常而没能修改,第一个表和第二个表都要回到未修改的状态,这就是所谓的事务回滚。

 

34、解释MySQL外连接、内连接与自连接的区别

  • 交叉连接: 交叉连接又叫笛卡尔积,它是指不使用任何条件,直接将一个表的所有记录和另一个表中的所有记录一一匹配。
  • 内连接 则是只有条件的交叉连接,根据某个条件筛选出符合条件的记录,不符合条件的记录不会出现在结果集中,即内连接只连接匹配的行。
  • 外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中
  • 的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。
  • 左外连接,也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL来填充。
  • 右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL目前还不支持全外连接。

 

35、简述在MySQL数据库中MyISAMInnoDB的区别

区别于其他数据库的最重要的特点就是其插件式的表存储引擎。切记:存储引擎是基于表的,而不是数据库。

InnoDBMyISAM的区别:

InnoDB存储引擎: 主要面向OLTP(Online Transaction Processing,在线事务处理)方面的应用,是第一个完整支持ACID事务的存储引擎(BDB第一个支持事务的存储引擎,已经停止开发)

特点:行锁设计、支持外键、支持事务、支持并发、锁粒度是支持mvcc得行级锁;

InnoDB:支持事务、外键等特性、数据行锁定。空间占用大,不支持全文索引等。

 

MyISAM存储引擎: MySQL官方提供的存储引擎,主要面向OLAP(Online Analytical Processing,在线分析处理)方面的应用。

特点:不支持事务,锁粒度是支持并发插入得表级锁,支持表所和全文索引。操作速度快,不能读写操作太频繁;

MyISAM:成熟、稳定、易于管理,快速读取。一些功能不支持(事务等),表级锁。

36、存储时期

  • Datatime:YYYY-MM-DD HH:MM:SS 格式存储时期时间,精确到秒,占用8个字节得存储空间,datatime类型与时区无关
  • Timestamp:以时间戳格式存储,占用4个字节,范围小1970-1-12038-1-19,显示依赖于所指定得时区,默认在第一个列行的数据修改时可以自动得修改timestamp列得值
  • Date:(生日)占用得字节数比使用字符串.datatime.int储存要少,使用date只需要3个字节,存储日期月份,还可以利用日期时间函数进行日期间得计算
  • Time:存储时间部分得数据

注意:不要使用字符串类型来存储日期时间数据(通常比字符串占用得储存空间小,在进行查找过滤可以利用日期得函数)
使用int存储日期时间不如使用timestamp类型;

37、了解XSS攻击吗?如何防止?

XSS是跨站脚本攻击,首先是利用跨站脚本漏洞以一个特权模式去执行攻击者构造的脚本,然后利用不安全的Activex控件执行恶意的行为。
使用htmlspecialchars()函数对提交的内容进行过滤,使字符串里面的特殊符号实体化。

38SQL注入漏洞产生的原因?如何防止?

SQL注入产生的原因:程序开发过程中不注意规范书写sql语句和对特殊字符进行过滤,导致客户端可以通过全局变量POSTGET提交一些sql语句正常执行。

防止SQL注入的方式:

  • 开启配置文件中的magic_quotes_gpc magic_quotes_runtime设置
  • 执行sql语句时使用addslashes进行sql语句转换
  • Sql语句书写尽量不要省略双引号和单引号。
  • 过滤掉sql语句中的一些关键词:updateinsertdeleteselect*
  • 提高数据库表和字段的命名技巧,对一些重要的字段根据程序的特点命名,取不易被猜到的。
  • Php配置文件中设置register_globalsoff,关闭全局变量注册
  • 控制错误信息,不要在浏览器上输出错误信息,将错误信息写到日志文件中。

SQL注入的特点:

  • 变种极多,攻击简单,危害极大
  • sql注入的主要危害
  • 未经授权操作数据库的数据
  • 恶意纂改网页
  • 私自添加系统账号或者是数据库使用者账号
  • 网页挂木马

39、完整性约束包括哪些?

答:数据完整性(Data Integrity)是指数据的精确(Accuracy)和可靠性(Reliability)

分为以下四类:

  1. 实体完整性:规定表的每一行在表中是惟一的实体。
  2. 域完整性:是指表中的列必须满足某种特定的数据类型约束,其中约束又包括取值范围、精度等规定。
  3. 参照完整性:是指两个表的主关键字和外关键字的数据应一致,保证了表之间的数据的一致性,防止了数据丢失或无意义的数据在数据库中扩散。
  4. 用户定义的完整性:不同的关系数据库系统根据其应用环境的不同,往往还需要一些特殊的约束条件。用户定义的完整性即是针对某个特定关系数据库的约束条件,它反映某一具体应用必须满足的语义要求。

与表有关的约束:包括列约束(NOT NULL(非空约束))和表约束(PRIMARY KEYforeign keycheckUNIQUE)

40SQL语句中相关子查询非相关子查询有什么区别?


答:子查询:嵌套在其他查询中的查询称之。

子查询又称内部,而包含子查询的语句称之外部查询(又称主查询)。

所有的子查询可以分为两类,即相关子查询和非相关子查询

  • 非相关子查询是独立于外部查询的子查询,子查询总共执行一次,执行完毕后将值传递给外部查询。
  • 相关子查询的执行依赖于外部查询的数据,外部查询执行一行,子查询就执行一次。

 非相关子查询相关子查询效率高

 

待续更新~~~

 

 

posted @ 2019-06-26 18:04  墨染尘  阅读(466)  评论(0编辑  收藏  举报
Paris