MyBatis简介
核心总结:
默认情况,自动生成的 SQL映射文件,默认 Mybatis的查询,只会返回字段给bean,bean中的子对象是不存在的。
除非自己自定义bean中的子对象 ,和自定义SQL语句,并将sql语句返回的属性赋值给子对象的属性中。
事实情况举例如下:
{"code":100,"msg":"处理成功!","extend":{"emp":{"empId":1,"empName":"Jerry","gender":"M","email":"[email protected]","dId":1,"department":null}}}
原是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation 迁移到了Google Code,随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis ,代码于2013年11月迁移到Github(下载地址见后)。
iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
MyBatis 是支持定制化SQL、存储过程以及高级映射的优秀的持久层框架。
MyBatis 避免了几乎所有的JDBC 代码和手动设置参数以及获取结果集。
MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.
MyBatis用处
MyBatis是一个半自动化的持久化层框架。
•JDBC
–SQL夹在Java代码块里,耦合度高导致硬编码内伤
–维护不易且实际开发需求中sql是有变化,频繁修改的情况多见
•Hibernate和JPA
–长难复杂SQL,对于Hibernate而言处理也不容易
–内部自动生产的SQL,不容易做特殊优化。
–基于全映射的全自动框架,大量字段的POJO进行部分映射时比较困难。导致数据库性能下降。
•对开发人员而言,核心sql还是需要自己优化
•sql和java编码分开,功能边界清晰,一个专注业务、一个专注数据。
mybatis下载
1、https://github.com/mybatis/mybatis-3/
2、http://central.maven.org/maven2/org/mybatis/mybatis/3.4.6/