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

mybatis中实现让返回值与bean中字段相匹配

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

mybatis中实现让返回值与bean中字段相匹配

1. 编写目的

这个介绍的与那些修改mybatis.xml文件的方法不一样,目的也不一样。

当我们需要查询的数据跟entity的bean完全不匹配的时候(比如说需要统计的时候),我们不可能写多个dao层的查询接口,然后一个一个map到xml中去。

我们可以专门写一个类,根据自己的需要把统计的属性都写到里面去,然后一次性查询,就可以获得所有需要统计的数据。

2. 重要方法

专门编写一个实体类。实体类中包含的都是自己需要统计的属性。

编写dao层的接口方法的返回值就是这个实体类。

在映射的map.xml中编写查询时,使用as …的方法与实体类中的属性一一对应。

3. 具体案例

需求:需要统计日记表中某个用户的以下属性:

总共编写日记数目

删除日记数目

心情开心篇数

心情一般篇数

心情差篇数

心情极差篇数

晴朗天气篇数

阴天篇数

雨天篇数

实体类的编写

package cn.ailanglang.diary.util;

public class StatisticBean {
  private Integer sum;
  private Integer mood0;
  private Integer mood1;
  private Integer mood2;
  private Integer mood3;
  private Integer weather0;
  private Integer weather1;
  private Integer weather2;
  private Integer weather3;
  private Integer weather4;
  private Integer weather5;
  private Integer weather6;
  private Integer weather7;
  
  private Integer unknow_weather;
  private Integer unknow_mood;

  public Integer getSum() {
    return sum;
  }

  public void setSum(Integer sum) {
    this.sum = sum;
  }

  public Integer getWeather0() {
    return weather0;
  }

  public void setWeather0(Integer weather0) {
    this.weather0 = weather0;
  }

  public Integer getWeather1() {
    return weather1;
  }

  public void setWeather1(Integer weather1) {
    this.weather1 = weather1;
  }

  public Integer getWeather2() {
    return weather2;
  }

  public void setWeather2(Integer weather2) {
    this.weather2 = weather2;
  }

  public Integer getWeather3() {
    return weather3;
  }

  public void setWeather3(Integer weather3) {
    this.weather3 = weather3;
  }

  public Integer getWeather4() {
    return weather4;
  }

  public void setWeather4(Integer weather4) {
    this.weather4 = weather4;
  }

  public Integer getWeather5() {
    return weather5;
  }

  public void setWeather5(Integer weather5) {
    this.weather5 = weather5;
  }

  public Integer getWeather6() {
    return weather6;
  }

  public void setWeather6(Integer weather6) {
    this.weather6 = weather6;
  }

  public Integer getWeather7() {
    return weather7;
  }

  public void setWeather7(Integer weather7) {
    this.weather7 = weather7;
  }

  public Integer getUnknow_weather() {
    return unknow_weather;
  }

  public void setUnknow_weather(Integer unknow_weather) {
    this.unknow_weather = unknow_weather;
  }

  public Integer getUnknow_mood() {
    return unknow_mood;
  }

  public void setUnknow_mood(Integer unknow_mood) {
    this.unknow_mood = unknow_mood;
  }

  public Integer getMood0() {
    return mood0;
  }

  public void setMood0(Integer mood0) {
    this.mood0 = mood0;
  }

  public Integer getMood1() {
    return mood1;
  }

  public void setMood1(Integer mood1) {
    this.mood1 = mood1;
  }

  public Integer getMood2() {
    return mood2;
  }

  public void setMood2(Integer mood2) {
    this.mood2 = mood2;
  }

  public Integer getMood3() {
    return mood3;
  }

  public void setMood3(Integer mood3) {
    this.mood3 = mood3;
  }
}

dao层接口方法

  
  StatisticBean countMood(Long userid);

mapper.xml的编写

重点注意as …


    select
     count(diary.pk_diaryid) as sum,
     sum(case when diary.mood='0' then 1 else 0 end) as mood0,
     sum(case when diary.mood='1' then 1 else 0 end) as mood1,
     sum(case when diary.mood='2' then 1 else 0 end) as mood2,
     sum(case when diary.mood='3' then 1 else 0 end) as mood3,
     sum(case when diary.weather='0' then 1 else 0 end) as weather0,
     sum(case when diary.weather='1' then 1 else 0 end) as weather1,
     sum(case when diary.weather='2' then 1 else 0 end) as weather2,
     sum(case when diary.weather='3' then 1 else 0 end) as weather3,
     sum(case when diary.weather='4' then 1 else 0 end) as weather4,
     sum(case when diary.weather='5' then 1 else 0 end) as weather5,
     sum(case when diary.weather='6' then 1 else 0 end) as weather6,
     sum(case when diary.weather='7' then 1 else 0 end) as weather7
    from user_diary,diary
    where diary.pk_diaryid = user_diary.fk_diaryid
    and user_diary.fk_userid = #{userid};
  

编写service层就不再介绍了。

测试类方法

 @Test
  public void test6() {
    StatisticBean statisticBean = diaryService.countMood((long) 25);
    System.out.println("sum=="+statisticBean.getSum());
    System.out.println("mood(0) == "+statisticBean.getMood0());
    System.out.println("mood(1) == "+statisticBean.getMood1());
    System.out.println("mood(2) == "+statisticBean.getMood2());
    System.out.println("mood(3) == "+statisticBean.getMood3());
    System.out.println("weather(0) == "+statisticBean.getWeather0());
    System.out.println("weather(1) == "+statisticBean.getWeather1());
    System.out.println("weather(2) == "+statisticBean.getWeather2());
    System.out.println("weather(3) == "+statisticBean.getWeather3());
    System.out.println("weather(4) == "+statisticBean.getWeather4());
    System.out.println("weather(5) == "+statisticBean.getWeather5());
    System.out.println("weather(6) == "+statisticBean.getWeather6());
    System.out.println("weather(7) == "+statisticBean.getWeather7());
  }

可以成功输出数据库中的数据,完成了我们的目的——统计。

4. 总结

重点了解一下as 的用法,as后面跟着的是实体类的属性名,当然xml文件中一定要指明returnType是那个实体类,注意要写详细的class地址。

然后就是理解一下 sum(case when diary.mood=‘3' then 1 else 0 end) as mood3,中sum和case when的用法。

补充知识:mybatis 学习总结3 表字段与javabean字段的映射

有时候我们封装的javabean与库表的字段并不能一一对应,我们需要做一些必要的配置以保证数据能够正确的获取。

总的来说,解决库表与javabean字段不统一的方法有以下几种。

1.驼峰转换

我们在封装实体类的时候,通常将属性命令为驼峰形式,例如

userName

而库表的命名则遵循全小写,多个单词间使用 '_' 下划线连接的方式, 例如

user_name

这种情况我们可以使用mybatis的驼峰转换策略 在mybatis 的config.xml配置文件中 添加如下代码:

 
  
    
    
  

添加如下策略后,针对查询结果集中的字段出现上例中的冲突时则能够得到解决。

2.sql语句中的 AS 关键字 — 起别名

我们在数据库建一个course表

create table course (
id BIGINT KEY AUTO_INCREMENT,
course_name VARCHAr(30) NOT NULL,
grade SMALLINT NOT NULL,
teacher_id BIGINT NOT NULL,
add_time TIMESTAMP DEFAULT now(),
mod_time TIMESTAMP DEFAULT now()
)

插入几条数据

INSERT INTO course (course_name,grade,teacher_id) VALUES ('高等数学',1,1);
INSERT INTO course (course_name,grade,teacher_id) VALUES ('微积分',2,2);
INSERT INTO course (course_name,grade,teacher_id) VALUES ('希腊文学史',3,3);

建立实体类

@Alias("courseBO")
public class CourseBO{

private Long courseId; //数据库-- id
private String courseName; //数据库 -- course_name
private Integer courseGrade; //数据库 -- grade
private Long courseTeacherId; //数据库 -- teacher_id
private Date addTime; //数据库 -- add_time
private Date modTime; //数据库 -- mod_time


}

可以简单的发现几个库表与实体字段的不同

mapper.xml





  
    SELECT
    id courseId,
    course_name,
    grade courseGrade,
    teacher_id courseTeacherId,
    add_time,
    mod_time
    FROM course WHERe id = #{id}
  
  
    
    
  

再次执行,结果:

可以看到数据正确的获取到了。

3.resultMap建立字段映射

我们也可以使用resultMap做字段映射

 
  
    
    
    
    
    
    
    
    
  

 
 
  

执行结果

以上这篇mybatis中实现让返回值与bean中字段相匹配就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持考高分网。

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

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

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