mybatis多表关联查询

mybatis多表关联查询

 一:在一个对象(User )中建立另一个对象属性(userExtend):

public class User implements Serializable{
	private static final long serialVersionUID = 1L;
	/** ID */
    private String id;
    /** 用户名 */
    private String username;
    /** 登录密码 */
    private String password;
    /** 用户扩展信息*/
private UserExtend userExtend;

GET/SET 方法省略
}

二:在第一个对象的mapper中的结果集书写:

  <resultMap id="ResultMap" type="cn.ss.umm.model.po.User">
    <id column="id" property="id" jdbcType="CHAR" />
    <result column="username" property="username"jdbcType="VARCHAR" />
<result column="password" property="password"
jdbcType="VARCHAR" />

<association property="userExtend" column="id"
 		javaType="cn.ss.umm.model.po.UserExtend">
    	 <id column="ue_id" property="id" jdbcType="CHAR" />
	    <result column="sex" property="sex" jdbcType="CHAR"/>
	    <result column="realname" property="realname"
jdbcType="VARCHAR"/>
	    <result column="qq" property="qq" jdbcType="VARCHAR" />
    </association>
</resultMap>

三:查询的SQL的书写:

  <select id="selectUserByPhoneOrEmail" parameterType="java.util.Map" resultMap="ThreeResultMap">
  	select a.*, b.*
  	from t_user a left join t_user_extend b on a.id = b.id
    <where>
    	<if test="qq!= null">
    		b.qq= #{qq}
    	</if>
    </where>
  </select>
时间: 2024-08-02 10:54:08

mybatis多表关联查询的相关文章

5.mybatis一对一表关联查询

方式一:嵌套结果:使用嵌套结果映射来处理重复的联合结果的子集,封装联表查询的数据(去除重复的数据)  SELECT * FROM class c,teacher t WHERE c.tid = t.tid AND c.cid=#{id} 方式二:嵌套查询,通过执行另外一个SQL 映射语句来返回预期的复杂类型  SELECT * FROM class c,teacher t WHERE c.tid = t.tid AND c.cid=#{id}  SELECT t.tid id, t.tname

mybatis的表关联查询,多个参数关联查询

在网上很多mybatis的关联查询资料,但是要用主表的多个条件查子表的资料少之又少,今天刚好用到了,就分享下给大家,多条件的写法.(主要是注意红色字体代码) 实体类: public class PhotoFeedback implements Serializable { private int id; private String name; private int userId; //用户id private List<PhotoFeedbackPic>  listPic; } photo

Hibernate-多表关联查询结果的处理方法

Hibernate多表查询结果处理 (2014-07-06 20:45:40) 转载▼ 标签: hibernate 多表查询 结果集处理 分类: Java 如果我们在Hibernate中需要查询多个表的不同字段,那么如何来获取Hibernate多表查询的结果呢?有两种方式: 1. 对各个字段分别转化成对应类型,如下: Java代码: Query q = session.createQuery(" select members, classInfo.className " + "

RDIFramework.NET 中多表关联查询分页实例

RDIFramework.NET 中多表关联查询分页实例 RDIFramework.NET,基于.NET的快速信息化系统开发.整合框架,给用户和开发者最佳的.Net框架部署方案.该框架以SOA范式作为指导思想,作为异质系统整合与互操作性.分布式应用提供了可行的解决方案. 分页非常的常见,基本任何项目都会涉及到分页,这没什么好谈的,大多数我们分页对单表的分页比较多,对多表的分页我们可以通过视图来实现,当然还有其他的方式,在这儿,我以一个实例展示下使用我们的RDIFramework.NET来实现多表

MySQL多表关联查询与存储过程

1.多表关联查询 --  **************关联查询(多表查询)**************** -- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 1.1 交叉连接查询(不推荐.产生笛卡尔乘积现象:4 * 4=16,有些是重复记录) SELECT empName,deptName FROM employee,dept; -- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 多表查询规则:1)确定查询哪些表   2)确定查询哪些字段   3)表与表之间连接条件

图解SQL多表关联查询

图解SQL多表关联查询 网上看了篇文章关于多表连接的,感觉很好,记录下来,以便日后自己学习  内连接 左连接 右连接 全外连接

Yii2中多表关联查询(join、joinwith) with是不执行sql的

Yii2中多表关联查询(join.joinwith) 我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer (id customer_name) 订单表Order (id order_name customer_id book_id) 图书表 (id book_name author_id) 作者表 (id author_name) 模型定义 下面是这4个个模型的定义,只写出其中的关联 Customer class Customer extends \

mark---[mysql多表关联查询的优化方法]

对于一个网站来说,数据库的结构至关重要.即要利于存储(入库不阻塞),又要利于查询(查询不锁表).网站数据库优化经验是一个积累的过程.下面就对多表关联查询的优化方法,举例说明. 现在社区分享类网站很火,就拿方维购物分享网站举例说明吧.也是对二次开发方维购物分享网站的一点总结,高手可以飞过. 购物分享的关键表有:分享表.图片表.文件表.评论表.标签表.分类表等. 围绕分享的表就么多,哇,那也不少啊.当我们查看一个图片的详细信息时,就要显示以上表里的信息.显示图片所属的分类.给图片打的标签.图片的评论

SQL两表关联查询&批量修改字段值

SQL关联查询&修改字段,正确范例如下: --批量修改报告单位名称&更新时间 --tt和tp两表关联查询,将符合条件的tt表中的principal字段更新到tp表的ruperson字段 merge into nhis34.t_publicplaces tp using standard.t_organization tt on (tt.orgcode = tp.r_orgcode and tp.create_time > '2015-05-07 00:00:00') when mat