mybatis一对一,一对多,多对多的关联查询

版权声明:本文为博主原创文章,创作不易,转载请注明出处。 https://blog.csdn.net/w1014074794/article/details/55504871
mybatis中一对一,一对多,多对多的处理:
http://www.cnblogs.com/yaobolove/p/5444046.html

http://www.360doc.com/content/14/0205/21/834950_350059484.shtml

http://www.cnblogs.com/junge/p/5145881.html


一对一: 使用association
<association property="teacher" javaType="Teacher">   


一对多和多对多:collection 
 <collection property="orders" ofType="com.yc.m.Orders">
 
 注意:相同字段要设置别名
如果两表联查,主表和明细表的主键都是id的话,明细表的多条只能查询出来第一条。
级联查询的时候,主表和从表有一样的字段名的时候,在mysql上命令查询是没问题的。

但在mybatis中主从表需要为相同字段名设置别名。设置了别名就OK了。


一对多关联查询示例:一个角色对应多个权限

<resultMap id="rolePowerMap" type="com.lakala.creditloan.manager.model.Role">
	    <id column="roleId" property="roleId" jdbcType="INTEGER" />
		<result column="ROLE_NAME" property="roleName" jdbcType="VARCHAR" />
		<result column="rdescri" property="describe" jdbcType="VARCHAR" />
		<collection property="powerlist"  ofType="com.lakala.creditloan.manager.model.Power">
		    <id column="powerid" property="id" jdbcType="INTEGER" />
		    <result column="POWER_NAME" property="powerName" jdbcType="VARCHAR" />
		    <result column="ACTION_URL" property="actionUrl" jdbcType="VARCHAR" />
		    <result column="PID" property="pid" jdbcType="INTEGER" />
		    <result column="LV" property="lv" jdbcType="INTEGER" />
		    <result column="ACTION_TYPE" property="actionType" jdbcType="INTEGER" />
		    <result column="pdescri" property="descri" jdbcType="VARCHAR" />
        </collection>
	</resultMap>


<select id="selectByRoleId" parameterType="java.lang.Integer" resultMap="rolePowerMap">
		  select r.ID roleId,r.ROLE_NAME,r.DESCRI rdescri,
			     p.ID powerid,p.POWER_NAME,p.ACTION_URL,p.ACTION_URL,p.PID,p.LV,p.ACTION_TYPE,p.DESCRI pdescri
			from rcs_role  r 
			     left  join rcs_role_power rp on r.id=rp.ROLE_ID 
			     left  join rcs_power p on p.ID=rp.POWER_ID  
			where r.ID=#{roleId,jdbcType=INTEGER}
	</select>




猜你喜欢

转载自blog.csdn.net/w1014074794/article/details/55504871