Mybatis 关联查询

首先看一下数据库表

t_user中powId所对应的是t_power表中的id

所以在进行关联查询是

public class User 
{
	private Integer id;				// id
	private String account;			// 用户名
	private String password;		// 密码
	private String nickname;		// 昵称
	private String telephone;		// 电话号码
	private Power  power;			// 权限
//省略set get方法
}

将power对象加入User实体中,并在powerDao中添加findByIdf方法,在userMapper 中

<resultMap type="User" id="UserResult">
		<result property="id" column="id" />
		<result property="account" column="account" />
		<result property="password" column="password" />
		<result property="nickname" column="nickname" />
		<result property="telephone" column="telephone" />
		<association property="power" column="powerId" select="com.ttms.dao.PowerDao.findById"></association>
	</resultMap>

进行添加时的SQL语句

<insert id="add" parameterType="User">
		insert into t_user values (null,#{account},#{password},#{nickname},#{telephone},#{power.id})
	</insert>

进行查询是的SQL语句

<select id="find" parameterType="Map" resultMap="UserResult">
		select * from t_user
		<if test="start!=null and size!=null">
		limit #{start},#{size}
		</if>
	</select>

在easyUI中进行获取时

<th field="cb" checkbox="true" align="center"></th>
				<th field="id" width="50" align="center">编号</th>
				<th field="account" width="100" align="center">用户名</th>
				<th field="password" width="150" align="center">密码</th>
				<th field="nickname" width="150" align="center">昵称</th>
				<th field="telephone" width="150" align="center">联系电话</th>
				<th field="power.name" width="150" align="center" formatter="formatTypeName">权限名称</th>
function formatTypeName(val,row)
	{
		return row.power.name;
	}



MyBatis关联查询是指在查询数据库时,通过配置映射文件,将多个表之间的关联数据查询来并进行组合。可以使用嵌套结果映射或嵌套查询来处理关联查询。 在嵌套结果映射中,可以使用\<resultMap>来定义映射关系,并使用\<association>来设置关联对象。例如,可以定义一个resultMap来映射Classes和Teacher表之间的关联关系,然后通过联表查询将两个表的数据关联起来。 另一种方式是使用嵌套查询,即在映射文件中通过\<select>标签设置嵌套查询语句来获取关联数据。通过联表查询获取到的数据可以作为嵌套查询的参数,从而获取到关联数据。 以上就是MyBatis关联查询的基本概念和使用方式。可以根据具体的需求选择合适的方式进行关联查询操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SSM框架的学习与应用-Java EE企业级应用开发学习记录(第四天)Mybatis关联映射和缓存机制](https://download.youkuaiyun.com/download/m0_53659738/88253127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mybatis关联查询](https://blog.youkuaiyun.com/faramita_of_mine/article/details/122202515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值