学MyBatis看这四篇就够了!(4)之一对多,多对一,分页查询以及Log4j的使用

2024-01-09 13:20

本文主要是介绍学MyBatis看这四篇就够了!(4)之一对多,多对一,分页查询以及Log4j的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MyBatis入门(4)

多对一查询第二种方法

首先,我们可以在sql上下个功夫:

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

查询到的结果就是上面的,我们所希望的也是上面的形式,其实本质上也是个连接查询

更新StudentMapper.java,增加方法:

package com.lwh.dao;import com.lwh.pojo.Student;
import java.util.List;public interface StudentMapper {List<Student> selectAll();//较为简单的查询方法List<Student> selectAll2();
}

更新StudentMapper.xml:

<select id="selectAll2" resultMap="StudentTeacher2">select s.id sid,s.name sname,s.tid,t.name tname from student s,teacher t where s.tid=t.id
</select><resultMap id="StudentTeacher2" type="Student"><result property="id" column="sid"/><result property="name" column="sname"/><association property="teacher" javaType="Teacher"><result property="id" column="tid"/><result property="name" column="tname"/></association>
</resultMap>

解析:

其实,不过就是把sql语句搬过来,再对Teacher对象进行根据id查询,首先看见id是selectAll2执行的sql语句,查询出来的字段有sid,sname,tid,tname这四个,所以在resultMap中有四个result的小标签,但是tid,tname其实是Teacher中的id和name属性,所以在student中的Teacher字段时需要用到association的标签进行对象包裹,里面的两个字段就是id和name,分别对应sql查询结果的tid和tname。

编写测试类:

@Test
public void testStudent2(){SqlSession sqlSession = MybatisUtils.getSqlSession();StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);List<Student> list = mapper.selectAll2();for (Student student:list) {System.out.println(student);}sqlSession.close();
}

运行结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ypSOgpCf-1627023751939)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210715123250667.png)]

一对多查询

创建子项目

Student:

package com.lwh.pojo;public class Student {private int id;private String name;private int tid;public int getId() {return id;}@Overridepublic String toString() {return "Student{" +"id=" + id +", name='" + name + '\'' +", tid=" + tid +'}';}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getTid() {return tid;}public void setTid(int tid) {this.tid = tid;}
}

Teacher:

由于一个老师可以教很多个学生,所以老师对应的属性学生中是一个泛型为Student的list,属于一对多的关系

package com.lwh.pojo;import java.util.List;public class Teacher {private int id;private String name;private List<Student> students;@Overridepublic String toString() {return "Teacher{" +"id=" + id +", name='" + name + '\'' +", students=" + students +'}';}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public List<Student> getStudents() {return students;}public void setStudents(List<Student> students) {this.students = students;}
}

编写Dao层:

根据id来查询老师信息

package com.lwh.dao;import com.lwh.pojo.Teacher;
import org.apache.ibatis.annotations.Param;public interface TeacherMapper {Teacher selectById(@Param("tid") int id);
}

编写TeacherMapper.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lwh.dao.TeacherMapper"><select id="selectById" resultMap="TeacherStudent">select s.id sid,s.name sname,s.tid,t.name tname from student s,teacher t where s.tid=t.id and t.id=#{tid}</select><resultMap id="TeacherStudent" type="Teacher"><result property="id" column="tid"/><result property="name" column="tname"/><collection property="students" ofType="student"><result property="id" column="sid"/><result property="name" column="sname"/><result property="tid" column="tid"/></collection></resultMap>
</mapper>

解析:

  1. sql语句和上一个多对一的例子差不多,只不过加了一个根据tid来查询老师的信息
  2. 同样需要用到reslutMap来表示这样的多对一的关系
  3. 我们要得到的是Teacher对象,所以resultMap中type是Teacher
  4. 里面共有三个字段,一个是老师的id,一个是老师的名字,对应关系是property对应对象的属性名,column对应的是查询到的字段名
  5. 其中由于是一对多的关系,所以需要用到collection标签,对应到的属性名是students,但是类型因为是list,并且泛型为student,所以不能用javatype,只能用oftype,所以oftype中给到的是student
  6. 在collection中的字段就是属于学生的字段了,分别是id,name,tid,就不做过多赘述

编写测试类

@Testpublic void test2(){    SqlSession sqlSession = MybatisUtils.getSqlSession();    TeacherMapper mapper = sqlSession.getMapper(TeacherMapper.class);    Teacher teacher = mapper.selectById(1);    System.out.println(teacher);    sqlSession.close();}

运行

成功!

分页查询

更新StudentMapper.java:
package com.lwh.dao;import com.lwh.pojo.Student;
import org.apache.ibatis.annotations.Select;import java.util.List;
import java.util.Map;public interface StudentMapper {@Select("select * from student")List<Student> selectAll();//分页查询方法List<Student> getUserByLimit(Map<String,Object> map);
}
更新StudentMapper.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lwh.dao.StudentMapper">
<select id="getUserByLimit" parameterType="map" resultType="Student">select * from student limit #{startIndex},#{pageSize}
</select></mapper>
编写测试类
/*** 分页测试*/
@Test
public void test3(){SqlSession sqlSession = MybatisUtils.getSqlSession();StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);//startIndex是分页的页数,pageSize是每页所显示的记录数HashMap<String, Object> hashMap = new HashMap<>();hashMap.put("startIndex",1);hashMap.put("pageSize",2);List<Student> list = mapper.getUserByLimit(hashMap);for (Student student:list){System.out.println(student);}sqlSession.close();}

由于实现比较简单,就不做一一赘述

使用Log4j打印日志
使用maven引入依赖
<dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version>
</dependency>
绑定log4j配置文件

在resources文件下创建log4j.properties文件,写入

#将等级为DEBUG的日志信息输出到console和file这两个目的地,console和file的定义在下面的代码
log4j.rootLogger=DEBUG,console,file#控制台输出的相关设置
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n#文件输出的相关设置
log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./log/lwh.log
log4j.appender.file.MaxFileSize=10mb
log4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yy-MM-dd}][%c]%m%n#日志输出级别
log4j.logger.org.mybatis=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
测试类中进行绑定
static Logger logger=Logger.getLogger(test.class);

可以看到每次运行控制台都会输出一串字符

preparing显示的是执行的sql语句

parameters显示的是占位符做的参数

total显示的值是查询到的总记录数

这篇关于学MyBatis看这四篇就够了!(4)之一对多,多对一,分页查询以及Log4j的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587244

相关文章

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]