mybatis初识理论

mybatis是持久层框架,apache的项目。
mybatis通过映射方式,半自动化的生成sql语句。
可以将preparedStatement中的参数自动进行输入映射,并将结果集映射成java对象(输出映射)

框架环境
mybatis全局配置文件配置数据源,事务等
mapper.xml映射文件,配置sql
SqlSessionFactory(会话工厂)
作用:创建SqlSession
SqlSession(会话)
作用:操作数据库
Executor(执行器)
作用:SqlSession内部通过执行器操作数据库
Mappered Statement(底层的封装对象)
作用:对sql/输入参数/输出结果类型进行封装

1、Mybatis实现了接口绑定,使用更加方便。
      在ibatis2.x中我们需要在DAO的实现类中指定具体对应哪个xml映射文件, 而Mybatis实现了DAO接口与xml映射文件的绑定,自动为我们生成接口的具体实现,使用起来变得更加省事和方便。
2、对象关系映射的改进,效率更高
3、MyBatis采用功能强大的基于OGNL的表达式来消除其他元素( OGNL是Object-Graph Navigation Language的缩写,它是一种功能强大的表达式语言,通过它简单一致的表达式语法,可以存取对象的任意属性,调用对象的方法,遍历整个对象的结构图,实现字段类型转化等功能。它使用相同的 表达式 去存取对象的属性。

MyBatis的优缺点
  
优点:
1、简单易学
       mybatis本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  
2、灵活
       mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql基本上可以实现我们不使用数据访问框架可以实现的所有功能,或许更多。
  
3、解除sql与程序代码的耦合
       通过提供DAL层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
 
4、提供映射标签,支持对象与数据库的orm字段关系映射
  
5、提供对象关系映射标签,支持对象关系组建维护
 
6、提供xml标签,支持编写动态sql。
 
缺点:
 
1、编写SQL语句时工作量很大,尤其是字段多、关联表多时,更是如此。
  
2、SQL语句依赖于数据库,导致数据库移植性差,不能更换数据库。
  
3、框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
  
4、二级缓存机制不佳
 
总结
 
       mybatis的优点同样是mybatis的缺点,正因为mybatis使用简单,数据的可靠性、完整性的瓶颈便更多依赖于程序员对sql的使用水平上了。sql写在xml里,虽然方便了修改、优化和统一浏览,但可读性很低,调试也非常困难,也非常受限。
      mybatis没有hibernate那么强大,但是mybatis最大的优点就是简单小巧易于上手,方便浏览修改sql语句。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值