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