一、一对多(XML配置)
1.dao持久层接口的实现部分
(1).AccountDao
public interface AccountDao {
List<Account> findAll();
List<AccountUser> findAllAccount();
}
(2).UserDao
public interface AccountDao {
List<Account> findAll();
List<AccountUser> findAllAccount();
}
2.domain的实现类
(1).Account
public class Account implements Serializable {
private Integer id;
private Integer uid;
private double money;
private User user;
}
(2).AccountUser
public class AccountUser extends Account {
private String username;
private String address;
}
(3).User
public class User {
private Integer id;
private String username;
private String address;
private String sex;
private Date birthday;
private List<Account> accounts;
}
3.resources中配置
(1).AccountDao.xml
<?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="com.hugong.dao.AccountDao">
<!-- 定义封装account和user的resultMap -->
<resultMap id="accountUserMap" type="account">
<id property="id" column="aid"></id>
<result property="uid" column="uid"></result>
<result property="money" column="money"></result>
<!-- 一对一的关系映射:配置封装user的内容 -->
<association property="user" column="uid" javaType="user">
<id property="id" column="id"></id>
<result column="username" property="username"></result>
<result column="address" property="address"></result>
<result column="sex" property="sex"></result>
<result column="birthday" property="birthday"></result>
</association>
</resultMap>
<!-- 查询所有用户 -->
<select id="findAll" resultMap="accountUserMap">
select u.*,a.id as aid,a.uid,a.money from account a , user u where u.id = a.uid;
</select>
<!-- 查询所有用户,并且带有用户名称和地址信息 -->
<select id="findAllAccount" resultType="accountUser">
select a.*,u.username,u.address from account a ,user u where u.id = a.uid
</select>
</mapper>
(2).UserDao.xml
<?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="com.hugong.dao.UserDao">
<!-- 定义封装account和user的resultMap -->
<resultMap id="userAccountMap" type="user">
<id property="id" column="id"></id>
<result column="username" property="username"></result>
<result column="address" property="address"></result>
<result column="sex" property="sex"></result>
<result column="birthday" property="birthday"></result>
<!-- 配置user对象中accounts集合映射 -->
<collection property="accounts" ofType="account">
<id property="id" column="aid"></id>
<result property="uid" column="uid"></result>
<result property="money" column="money"></result>
</collection>
</resultMap>
<!-- 查询所有用户 -->
<select id="findAll" resultMap="userAccountMap">
select * from user u left outer join account a on u.id = a.uid
</select>
<!-- 根据id查询用户信息 -->
<select id="findById" parameterType="int" resultType="user">
select * from user where id = #{id};
</select>
</mapper>
(3).SqlMapConfig.xml
<?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-->
<properties resource="jdbcConfig.properties">
</properties>
<!-- 使用typeAliases配置别名,它只能配置domain中的类的别名-->
<typeAliases>
<package name="com.hugong.domain"></package>
</typeAliases>
<!-- 配置环境 -->
<environments default="mysql">
<!-- 配置mysql环境 -->
<environment id="mysql">
<!-- 配置事务 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 配置连接池 -->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</dataSource>
</environment>
</environments>
<!-- 配置映射文件的位置 -->
<mappers>
<!--<mapper resource="com/hugong/dao/UserDao.xml"></mapper>-->
<!-- package标签用于指定dao接口所在的包,当指定了之后就不需要再写mapper以及resource或者class了 -->
<package name="com.hugong.dao"></package>
</mappers>
</configuration>
4.测试类的代码实现
(1).MybatisTestAccount
public class MybatisTestAccount {
private InputStream is;
private SqlSession sqlSession;
private AccountDao accountDao;
@Before
public void init() throws IOException {
is = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
sqlSession = factory.openSession();
accountDao = sqlSession.getMapper(AccountDao.class);
}
@After
public void destory() throws IOException {
sqlSession.close();
is.close();
}
@Test
public void testFindAll() {
List<Account> accounts = accountDao.findAll();
for (Account account : accounts) {
System.out.println("----- 每一个account的信息 -----");
System.out.println(account);
System.out.println(account.getUser());
}
}
@Test
public void testFindAllAccount() {
List<AccountUser> aus = accountDao.findAllAccount();
for(AccountUser au : aus) {
System.out.println(aus);
}
}
}
(2).MybatisTestUser
public class MybatisTestUser {
private InputStream is;
private SqlSession sqlSession;
private UserDao userDao;
@Before
public void init() throws IOException {
is = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
sqlSession = factory.openSession();
userDao = sqlSession.getMapper(UserDao.class);
}
@After
public void destory() throws IOException {
sqlSession.close();
is.close();
}
@Test
public void testFindAll() throws IOException {
List<User> users = userDao.findAll();
for (User user : users) {
System.out.println("每个用户user的信息");
System.out.println(user);
System.out.println(user.getAccounts());
}
}
@Test
public void testFindByid() {
User user = userDao.findById(46);
System.out.println(user);
}
}
二、多对多(XML配置)
1.dao持久层接口的实现
(1).RoleDao
public interface RoleDao {
List<Role> findAll();
}
(2).UserDao
public interface UserDao {
List<User> findAll();
}
2.domain实现
(1).Role
public class Role {
private int roleId;
private String roleName;
private String roleDesc;
private List<User> users;
}
(2).User
public class User {
private Integer id;
private String username;
private String address;
private String sex;
private Date birthday;
private List<Role> roles;
}
3.resources的配置
(1).RoleDao.xml
<?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="com.hugong.dao.RoleDao">
<!-- 定义role表的ResultMap -->
<resultMap id="roleMap" type="role">
<id property="roleId" column="rid"></id>
<result property="roleName" column="role_name"></result>
<result property="roleDesc" column="role_desc"></result>
<!-- 配置用户信息集合的映射 -->
<collection property="users" ofType="user">
<id property="id" column="id"></id>
<result property="sex" column="sex"></result>
<result property="username" column="username"></result>
<result property="birthday" column="birthday"></result>
<result property="address" column="address"></result>
</collection>
</resultMap>
<select id="findAll" resultMap="roleMap">
select u.*,r.id as rid , r.role_name, r.role_desc from role r
left outer join user_role ur on r.id = ur.rid
left outer join user u on u.id = ur.uid
</select>
</mapper>
(2).UserDao.xml
<?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="com.hugong.dao.UserDao">
<!-- 定义封装account和user的resultMap -->
<resultMap id="userMap" type="user">
<id property="id" column="id"></id>
<result property="username" column="username"></result>
<result property="address" column="address"></result>
<result property="sex" column="sex"></result>
<result property="birthday" column="birthday"></result>
<!-- 配置角色信息集合的映射 -->
<collection property="roles" ofType="role">
<id property="roleId" column="rid"></id>
<result property="roleName" column="role_name"></result>
<result property="roleDesc" column="role_desc"></result>
</collection>
</resultMap>
<!-- 查询所有用户 -->
<select id="findAll" resultMap="userMap">
select u.*,r.id as rid , r.role_name, r.role_desc from user u
left outer join user_role ur on u.id = ur.uid
left outer join role r on r.id = ur.rid
</select>
</mapper>
(3).SqlMapConfig.xml
<?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-->
<properties resource="jdbcConfig.properties">
</properties>
<!-- 使用typeAliases配置别名,它只能配置domain中的类的别名-->
<typeAliases>
<package name="com.hugong.domain"></package>
</typeAliases>
<!-- 配置环境 -->
<environments default="mysql">
<!-- 配置mysql环境 -->
<environment id="mysql">
<!-- 配置事务 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 配置连接池 -->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</dataSource>
</environment>
</environments>
<!-- 配置映射文件的位置 -->
<mappers>
<!--<mapper resource="com/hugong/dao/UserDao.xml"></mapper>-->
<!-- package标签用于指定dao接口所在的包,当指定了之后就不需要再写mapper以及resource或者class了 -->
<package name="com.hugong.dao"></package>
</mappers>
</configuration>
4.测试类
(1).MybatisTestRole
public class MybatisTestRole {
private InputStream is;
private SqlSession sqlSession;
private RoleDao roleDao;
@Before
public void init() throws IOException {
is = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
sqlSession = factory.openSession();
roleDao = sqlSession.getMapper(RoleDao.class);
}
@After
public void destory() throws IOException {
sqlSession.close();
is.close();
}
@Test
public void testFindAll() {
List<Role> roles = roleDao.findAll();
for (Role role : roles) {
System.out.println("----- 每个用户的角色信息 -----");
System.out.println(role);
System.out.println(role.getUsers());
}
}
}
(2).MybatisTestUser
public class MybatisTestUser {
private InputStream is;
private SqlSession sqlSession;
private UserDao userDao;
@Before
public void init() throws IOException {
is = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
sqlSession = factory.openSession();
userDao = sqlSession.getMapper(UserDao.class);
}
@After
public void destory() throws IOException {
sqlSession.close();
is.close();
}
@Test
public void testFindAll() throws IOException {
List<User> users = userDao.findAll();
for (User user : users) {
System.out.println("每个用户user的信息");
System.out.println(user);
System.out.println(user.getRoles());
}
}
}