栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【Mybatis】(2)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【Mybatis】(2)

文章目录
  • assciation和collection
  • 多对一
      • 子查询
      • 联表查询
  • 一对多
  • 动态SQL
      • if语句
      • switch语句
      • where标签
      • set标签
      • trim标签
      • sql片段(封装)
      • foreach标签

assciation和collection

association用来表示对象,collection用来表示集合

多对一 子查询


数据库的表如图所示,需求是查询学生和他们对应的老师信息。
实体类对象(pojo)如下:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {
    private int id;
    private String name;
    //private int tid;
    private Teacher teacher;
}
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Teacher {
    private int id;
    private String name;
}

学生的属性除了自己的id和姓名,还嵌套了一个老师类。
将查询的mapper这么写


    select * from student;


    
    
    


    select s.id sid,s.name sname,s.tid ,t.name tname
    from student s,teacher t
    where s.tid=t.id;


    
    
    
        
        
    

理解一下mapper的做法:

  1. sql语句利用外键联表查询4个字段
  2. 结果集映射,将Student类的 id 和 name 分别对应查出来重命名的 sid 和 sname
  3. 关联剩下的两个结果,Student类的teacher参数所对应的类是Teacher,将查出来的 tid 和 tname 分别映射到teacher中的 id 和 name 上。

一对多

需求是查询每个老师对应的学生
老师类:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Teacher {
    private int id;
    private String name;
    private List student;
}

学生类:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {
    private int id;
    private String name;
}

mapper内的语句:


	select * from blog where 1=1
	
		and  title=#{title}
	

switch语句

mybatis里用的是choose-when-other,相当于Java里的switch-case-default,举个例子,需求还是当没提供 title 时,所有的博客全部查出来,提供了 title 时,查指定的博客


	select * from blog 
	
		
			and  title=#{title}
		
	

当where标签里,有一个子句被调用,查询语句就会加上where关键字。
如果子句里有AND或者OR,并且作为where标签下第一个满足条件的子句,那么mybatis会帮助我们去掉这个AND或OR。

set标签

类似于where标签,用于update标签,举个例子:
更新用户表的id和name
普通的sql语句:

update user set name="张三" where id=1

mybatis中使用set标签,变成动态修改后


	update user
	
		
			name=#{name},
		
	
	where id=#{id};

set标签会去掉多余的,(逗号)

trim标签

是 where 和 set 的父类,不常用


	···


	···

sql片段(封装)

将一些sql 的公共部分抽取出来,方便复用,建议基于单表使用(少用)


	···



	···
		
	···

标签装需复用sql语句,加上id以便调用。在sql体内使用标签引用

foreach标签

用于在集合遍历,collection表示遍历的集合item,表示遍历出来的每个元素,index表示,open表示集合以什么开头,separator表示分隔符,close表示集合以什么结束


所以遍历的集合类似于:(id1,id2,id3)
这个查询语句本质就是在mybatis.blog里,如果ids里面有元素就根据这些id分别查询行,没有的话就全部查询(不加where语句)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/851654.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号