MyBatis(一)原理过程实现crud以及自增主键的返回

本文介绍了MyBatis框架的原理和使用,包括对比原生jdbc和Spring JdbcTemplate的问题,详细阐述了MyBatis的配置文件、SqlSessionFactory、SqlSession以及Mapper映射文件。通过实例演示了MyBatis如何实现根据id和name查询,以及添加、删除和更新操作。还特别讨论了如何处理自增主键和非自增主键的返回问题。
摘要由CSDN通过智能技术生成

MyBatis是一个用在持久层的框架,也就是操作数据库的。

在前面的学习中,我们通过原生jdbc操作数据库。以及spring框架中封装的JdbcTemplate框架来操作数据库。

原生态jdbc程序问题

(1)数据库的连接关闭操作复杂,效率慢

(2)sql语句的编写和preparedStatement执行sql语句中注入参数都是在java语句中,是硬编码

(3)从resutSet中遍历结果集数据时,存在硬编码,将获取表的字段进行硬编码,不利于系统维护

硬编码是指将可变变量用一个固定值来代替的方法,用这种方法编译后,如果以后需要更改此变量就非常困难了

spring框架中封装的JdbcTemplate框架

可以在配置文件中,配置了c3p0数据连接池,这方面改善了,但是还是存在硬编码问题


 

MyBatis框架原理

(1)全局配置文件SqlMapConfig.xml,里面配置数据源,事务,运行环境

(2)sqlSessionFactory会话工厂,根据配置文件来创建工厂,它的作用就是产生sqlSeesion

(3)sqlSeesion会话,是一个接口,用来执行sql语句,调用Executor(执行器)来执行

(4)在mybatis中sql语句不再写到java程序代码中,而是写在mapper.xml的配置文件中,这叫做表的映射文件。比如在我们的项目中对应的表有很多。有user表,item表,对这些表都会有增删改查的操作,我们就会为这些表都创建映射文件然后在文件中配置相应的sql语句,然后通过sqlSession来执行。但是前面说SqlMapConfig.xml是全局配置文件,所以要把所有的映射文件加载到全局配置文件

(4)mapped stattement底层封装对象,对数据库存储封装,包括sql语句,输入参数,输出参数类型等

总结:mybatis主要放在sq

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值