相关知识
myBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。 —摘自百度百科
其实要说的是Mybatis和Hibernate的一点区别,两个都是优秀的ORM框架,用过之后,感觉都很不错,但是Hibernate对于复制的SQL语句的支持有限,而Mybatis的不像Hibernate是用HQL,而是直接用SQL语句,需要接触数据库,需要知道数据库细节,但是同时也能更好的使用数据库的复杂查询。 Hibernate也能直接通过session获得数据库对象来操作操作复杂查询的,但是这样做,与Hibernate的初衷有点违背而已。
系统环境
- IDE:InterliJ IDEA 2017.1.4
- jdk版本:1.8
- Maven版本:3.5
- MyBatis版本:3.X
- 数据库:MySQL 5.7 包含user表的sql脚本
添加mybatis
(1) 引入依赖
<!-- ********************** Java Servlet API 4.0.0-b01 ********************** -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0-b01</version>
</dependency>
<!-- ********************** Mysql JDBC驱动 ********************** -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.6</version>
</dependency>
<!-- ********************** Mybatis依赖 ********************** -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.4</version>
</dependency>
<!-- ********************** junit单元测试依赖 ********************** -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
复制代码
添加Mybatis插件:
菜单:File->settings
添加Mybatis配置文件模板
模板内容:
package POJO; import java.util.Date;
/**
* Created by hui on 2017/6/17.
*/
public class User {
private int id;
private String name;
private Date birth;
private Integer sex;
private Integer age;
private String phone;
private String email;
private String pwd;
// 各属性getter和setter方法省略,toString方法
.....
复制代码
<mappers>
<mapper resource="UserDao.xml"></mapper>
</mappers>
复制代码
在UserDAO.xml添加如下:
<select id="getUserById" resultType="POJO.User">
SELECT * FROM USER WHERE id = #{id};
</select>
复制代码
在UserDAO.java添加如下:
//使用xml配置文件
User getUserById(int id);
//不使用配置文件使用注解
@Select("Select * from user where id = #{id}")
User getUserByIdForAnnotation(int id);
复制代码