mybatis入门教程(六)----关联查询之一对一

数据库表结构:

use bbs;

Drop TABLE IF EXISTS `article`;
Create TABLE `article` (
`id` int(11) NOT NULL auto_increment,
`userid` int(11) NOT NULL,
`title` varchar(100) NOT NULL,
`content` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;


-- ----------------------------
-- 添加几条测试数据
-- ----------------------------
Insert INTO `article` VALUES ('1', '1', 'test_title', 'test_content');
Insert INTO `article` VALUES ('2', '1', 'test_title_2', 'test_content_2');
Insert INTO `article` VALUES ('3', '1', 'test_title_3', 'test_content_3');
Insert INTO `article` VALUES ('4', '1', 'test_title_4', 'test_content_4');


select * from article;

create table user(
id int primary key,
userName varchar(50),
userAddress varchar(50),
userAge int(3)
)ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

insert into user values(1,'ppppp','aaaaaa',20);

commit;


实体类:  1

package com.mscncn.batis.model;

public class User {
	private int id;
	private int age;
	private String userName;
	private String userAddress;

	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getUserName() {
		return userName;
	}
	public void setUserName(String userName) {
		this.userName = userName;
	}
	public String getUserAddress() {
		return userAddress;
	}
	public void setUserAddress(String userAddress) {
		this.userAddress = userAddress;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
}

实体类: n

package com.mscncn.batis.model;

public class Article {
	private int id;
    private User user;
	private String title;
    private String content;
    public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public User getUser() {
		return user;
	}
	public void setUser(User user) {
		this.user = user;
	}
	public String getTitle() {
		return title;
	}
	public void setTitle(String title) {
		this.title = title;
	}
	public String getContent() {
		return content;
	}
	public void setContent(String content) {
		this.content = content;
	}
	@Override
	public String toString() {
		return "Article [id=" + id + ", user=" + user + ", title=" + title
				+ ", content=" + content + "]";
	}
}

在mybatis主配置文件中添加对应的配置:

 <typeAliases> 
    	   <!-- 实体类的别名 -->
    	   <!-- 注解使用package来指定包, -->
    	  <!--   <package name="com.mscncn.batis.model"/>-->
       <typeAlias alias="Posts" type="com.mscncn.batis.model.Posts"/> 
       <typeAlias alias="Pager" type="com.mscncn.batis.model.Pager"/> 
       <typeAlias alias="Article" type="com.mscncn.batis.model.Article"/> 
        <typeAlias alias="User" type="com.mscncn.batis.model.User"/> 
    </typeAliases>

 <mappers> 
    		<!--   -->
       <mapper resource="com/mscncn/batis/mapper/config/PostsMapper.xml" /> 
       <mapper resource="com/mscncn/batis/mapper/config/UserMapper.xml"/>
    </mappers>


UserMapper:

public interface UserMapper {
	public List<Article> getUserArticles(int id);
}

UserMapper.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"> 
<!-- 这里namespace必须是PostsMapper接口的路径,不然要运行的时候要报错 “is not known to the MapperRegistry”--> 
<mapper namespace="com.mscncn.batis.mapper.UserMapper"> 
	<select id="getUserArticles" parameterType="int" resultMap="resultUserArticleList">
       select user.id,user.userName,user.userAddress,article.id a_id,article.title,article.content from user,article 
              where user.id=article.userid and user.id=#{id}
    </select>
	
	<resultMap type="Article" id="resultUserArticleList">
		<id property="id" column="a_id"/>
		<result property="title" column="title"/>
		<result property="content" column="content"/>
		 <association property="user" javaType="User">
            <id property="id" column="id" />
            <result property="userName" column="userName" />
            <result property="userAddress" column="userAddress" />            
        </association>       
	</resultMap>

</mapper>

测试类:UserMapperTest

package com.mscncn.batis;

import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;

import com.mscncn.batis.mapper.UserMapper;
import com.mscncn.batis.model.Article;
import com.mscncn.batis.util.MyBatisUtil;

public class UserMapperTest {
	static SqlSessionFactory sqlSessionFactory = null; 
    static { 
       sqlSessionFactory = MyBatisUtil.getSqlSessionFactory(); 
    } 
    
    @Test 
    public void testAdd() { 
       SqlSession sqlSession = sqlSessionFactory.openSession(); 
       try { 
    	   		UserMapper mapper = sqlSession.getMapper(UserMapper.class); 
    	   		List<Article> list=mapper.getUserArticles(1);
    	   		for(Article a:list){
    	   			System.out.println(a);
    	   		}
           sqlSession.commit();//这里一定要提交,不然数据进不去数据库中 
       } finally { 
           sqlSession.close(); 
       } 
    } 
}



你可能感兴趣的:(mybatis入门教程(六)----关联查询之一对一)