Java面试题———Mysql篇①

目录

1、内连接和外连接的区别

2、drop、delete与truncate区别

3、union与union all的区别

4、char和varchar的区别

5、事务的四大特性

6、并发事务带来的问题

7、事务隔离级别


1、内连接和外连接的区别

内连接和外连接都是数据库进行多表联查时使用的连接方式,区别在于二者获取的数据集不同

内连接指的是使用左表中的每一条数据分别去连接右表中的每一条数据,仅仅显示出匹配成功的那部分

外连接有分为左外连接和右外连接

  • 左外连接: 首先要显示出左表的全部,然后使用连接条件匹配右表,能匹配中的就显示,匹配不中的显示为null

  • 右外连接: 首先要显示出右表的全部,然后使用连接条件匹配左表,能匹配中的就显示,匹配不中的显示为null

2、drop、delete与truncate区别

这个关键字都是MySQL中用于删除的关键字,区别在于:

  1. delete语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作

  2. drop 主要用于删除数据表、表中的列、索引等结构

  3. truncate 是直接把表删除,然后再重建表结构

这三种方式在效率方面drop 最高、truncate 其次、delete最低,但是drop和truncate 都不记录日志,无法回滚

3、union与union all的区别

union和union all都是MySQL中用于合并多条select语句结果的关键字,它会将前后两条select语句的结果组合到一个结果集合中

区别在于UNION ALL会返回所有结果,UNION会去掉重复的记录

4、char和varchar的区别

char和varchar是MySQL中的字符串类型,区别在于下面几方面:

  1. 最大长度:char最大长度是255字符,varchar最大长度是65535个字节

  2. 占用长度:char是定长的,不足的部分用隐藏空格填充,varchar是不定长的

  3. 空间使用:char会浪费空间,varchar会更加节省空间

  4. 查找效率:char查找效率会很高,varchar查找效率会更低

因此我们如果存储固定长度的列,例如身份证号、手机号建议使用char

其它不定长度的建议使用varchar,使用varchar的时候也要尽量让声明长度贴近实际长度

注意:varchar(50)中50的涵义是最多存放50个字符,varchar(50)和varchar(200)存储hello所占空间一样

5、事务的四大特性

事务的四大特性指的是原子性、一致性、隔离性、持久性

  • 原子性:事务是最小的执行单位,不允许分割,同一个事务中的所有命令要么全部执行,要么全部不执行

  • 一致性:事务执行前后,数据的状态要保持一致,例如转账业务中,无论事务是否成功,转账者和收款人的总额应该是不变的

  • 隔离性:并发访问数据库时,一个事务不被其他事务所干扰,各并发事务是独立执行的

  • 持久性:一个事务一旦提交,对数据库的改变应该是永久的,即使系统发生故障也不能丢失

6、并发事务带来的问题

并发事务下,可能会产生如下的问题:

  • 脏读:一个事务读取到了另外一个事务没有提交的数据

  • 不可重复读:一个事务读取到了另外一个事务修改的数据

  • 幻读(虚读):一个事务读取到了另外一个事务新增的数据

7、事务隔离级别

事务隔离级别是用来解决并发事务问题的方案,不同的隔离级别可以解决的事务问题不一样

  • 读未提交: 允许读取尚未提交的数据,可能会导致脏读、幻读或不可重复读

  • 读已提交: 允许读取并发事务已提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生

  • 可重复读: 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生

  • 可串行化: 所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,该级别可以防止脏读、不可重复读以及幻读。

上面的这些事务隔离级别效率依次降低,安全性依次升高,如果不单独设置,MySQL默认的隔离级别是可重复读

  • 18
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

啵啵薯条

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值