mybatis 使用mysql索引_mybatis使用及SQL语句优化小结

本文总结了MyBatis在查询、更新操作中的行为,以及常见的异常处理。并深入探讨了SQL优化,包括使用约束条件、LIMIT 1、避免LIKE通配符开头、创建索引、视图、临时表、JOIN操作的最佳实践,以及如何避免索引失效等。
摘要由CSDN通过智能技术生成

【摘要】 MyBatis 作为一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。

一、mybatis总结

1.mybatis查询/更新语句,没有找到符合条件的记录,会返回什么?

返回类型为String的, 实际返回null;

返回类型为对象的:实际返回null ;

返回类型为列表等集合: 实际返回空集合[];

返回类型为Boolean:实际返回false

当数据库语句插入条件不满足,会返回false;比如使用dual的SQL语句;

2.mybatis会抛出哪些常见异常?

不是所有的异常,都认为程序出异常要报错,

比如用户重复收藏商品,可以直接返回成功,这时候对“违反唯一键”异常要特殊处理。

(1) 插入语句

DataIntegrityViolationException: 违反非空约束、数据大小超过约束

DuplicateKeyException:违反唯一键约束

CannotAcquireLockException: for update nowait 超时

(2)更新语句

条件不满足时,会返回false

数据库操作应该判断返回值,比如下面BUG:

(3) bug类,表字段找不到等场景

MyBatisSystemException

BadSqlGrammarException

3.事务里面套用for update,看上去绕过了事务

等for update获取锁后&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值