一、快速入门
SqlMapConfig.xml
MyBatis主配置文件 用于 连接数据库 和 指定映射配置文件。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- mybatis的主配置文件 -->
<configuration>
<!-- 配置环境 -->
<environments default="mysql">
<!-- 配置MySQL的环境 -->
<environment id="mysql">
<!-- 配置事务的类型 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 配置数据源(连接池) -->
<dataSource type="POOLED">
<!-- 配置连接数据库的4个基本信息 -->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/eesy_mybatis"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- mapper标签 resource属性:指定映射配置文件的项目路径。 -->
<!-- mapper标签 class属性:指定被注解的持久层接口的全类名。 -->
<mappers>
<mapper resource="cn/water/dao/Dao.xml"/>
<mapper class="cn.water.dao.DaoAnno"/>
</mappers>
</configuration>
实体类
实体类 用于存储数据。
-
实体类要实现Serializable接口。因为在封装MySQL数据库数据时,运用了代理对象。
-
成员变量名和字段名保持一致。
public class User implements Serializable {
private Integer id;
private String username;
}
1、使用映射配置文件
Dao.java
持久层接口 用于定义抽象方法
public interface Dao {
public abstract List<User> findAll(); // 查询所有用户
}
Dao.xml
映射配置文件 用于编写SQL语法
映射配置文件 和 持久层接口 的关系:
- 一个持久层接口 对应 一个映射配置文件。
- 包相同。例如:src/main/java/cn/water/dao/ 和 src/main/resources/cn/water/dao/
- 文件名相同。例如:Dao**.java** 和 Dao**.xml**
<!--mapper namespace=持久层接口全类名 -->
<!-- select id=方法名 resultType=全类名 -->
<!-- SQL语句 -->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.water.dao.Dao">
<select id="findAll" resultType="cn.water.domain.User">
SELECT * FROM user;
</select>
</mapper>
2、使用注解
Dao.java
持久层接口 用于定义抽象方法
public interface UserDao {
@Select("SELECT * FROM user;")
public abstract List<User> findAll();
}
测试类
/* 读取配置文件,获取IO流 */
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");
/* 工厂构造者 */
SqlSessionFactoryBuilder sfb = new SqlSessionFactoryBuilder();
/* 工厂类 */
SqlSessionFactory sf = sfb.build(is);
/* SqlSession对象 */
SqlSession sqlSession = sf.openSession();
/* 持久层接口代理对象 */
UserDao dao = sqlSession.getMapper(Dao.class);
/* 执行方法 */
List<User> list = dao.findAll();
/* 遍历 */
for (User user : list) {
System.out.println(user);
}
/* 释放资源 */
sqlSession.close();
is.close();
二、主配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 外部配置 -->
<properties resource="jdbcConfig.properties"/>
<!-- 指定实体类的包-->
<typeAliases>
<package name="cn.water.domain"/>
</typeAliases>
<!-- 配置环境 -->
<environments default="mysql">
<environment id="mysql">
<transactionManager type="JDBC"/>
<!-- 配置连接池 -->
<dataSource type="POOLED">
<!-- 配置连接数据库的4个基本信息 -->
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>