MyBatis @Result注解基于一对一关联

示例:测试一对一关联

程序清单:com.mapper.PersonMapper.java

package com.mapper;
import org.apache.ibatis.annotations.One;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.mapping.FetchType;
import com.po.Person;
public interface PersonMapper {
	@Select("select * from t_person where id=#{id}")
	@Results({
		@Result(id=true,column="id",property="id"),
		@Result(column="name",property="name"),
		@Result(column="cid",property="card",
		one=@One(select="com.mapper.CardMapper.getCardById",
		fetchType=FetchType.EAGER))
	})
	Person getPersonById(Integer id);
}

程序清单:com.mapper.CardMapper.java

package com.mapper;
import org.apache.ibatis.annotations.Select;
import com.po.Card;
public interface CardMapper {
	@Select("select * from t_card where id=#{id}")
	Card getCardById(Integer id);
}

程序清单:com.po.Person.java

package com.po;
public class Person {
	private Integer id;
	private String name;
	private Card card;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Card getCard() {
		return card;
	}
	public void setCard(Card card) {
		this.card = card;
	}
	@Override
	public String toString() {
		return "Person [id=" + id + ", name=" + name + ", card=" + card + "]";
	}
}

程序清单:com.po.Card.java

package com.po;
public class Card {
	private Integer id;
	private String code;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getCode() {
		return code;
	}
	public void setCode(String code) {
		this.code = code;
	}
	@Override
	public String toString() {
		return "Card [id=" + id + ", code=" + code + "]";
	}
}

程序清单:/mybatis/src/mybatis-config.xml

<!-- 配置Mapper的位置 -->
	<mappers>
		<mapper class="com.mapper.PersonMapper"/>	
		<mapper class="com.mapper.CardMapper"/>			
	</mappers>

程序清单:com.dao.PersonDao.java

@Test
	public void getPersonById() throws IOException {
		session=getSqlSession();
		PersonMapper pm=session.getMapper(PersonMapper.class);
		Person person=pm.getPersonById(1);
		System.out.println(person);
	}

运行PersonDao的getPersonById()方法,控制台显示如下:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云淡风轻58

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值