日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配

瀏覽:36日期:2023-10-22 12:52:30

1. 編寫(xiě)目的

這個(gè)介紹的與那些修改mybatis.xml文件的方法不一樣,目的也不一樣。

當(dāng)我們需要查詢(xún)的數(shù)據(jù)跟entity的bean完全不匹配的時(shí)候(比如說(shuō)需要統(tǒng)計(jì)的時(shí)候),我們不可能寫(xiě)多個(gè)dao層的查詢(xún)接口,然后一個(gè)一個(gè)map到xml中去。

我們可以專(zhuān)門(mén)寫(xiě)一個(gè)類(lèi),根據(jù)自己的需要把統(tǒng)計(jì)的屬性都寫(xiě)到里面去,然后一次性查詢(xún),就可以獲得所有需要統(tǒng)計(jì)的數(shù)據(jù)。

2. 重要方法

專(zhuān)門(mén)編寫(xiě)一個(gè)實(shí)體類(lèi)。實(shí)體類(lèi)中包含的都是自己需要統(tǒng)計(jì)的屬性。

編寫(xiě)dao層的接口方法的返回值就是這個(gè)實(shí)體類(lèi)。

在映射的map.xml中編寫(xiě)查詢(xún)時(shí),使用as …的方法與實(shí)體類(lèi)中的屬性一一對(duì)應(yīng)。

3. 具體案例

需求:需要統(tǒng)計(jì)日記表中某個(gè)用戶(hù)的以下屬性:

總共編寫(xiě)日記數(shù)目

刪除日記數(shù)目

心情開(kāi)心篇數(shù)

心情一般篇數(shù)

心情差篇數(shù)

心情極差篇數(shù)

晴朗天氣篇數(shù)

陰天篇數(shù)

雨天篇數(shù)

實(shí)體類(lèi)的編寫(xiě)

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層接口方法

/** * 統(tǒng)計(jì) * @param userid * @return */ StatisticBean countMood(Long userid);

mapper.xml的編寫(xiě)

重點(diǎn)注意as …

<select parameterType='java.lang.Long' resultType='cn.smileyan.diary.util.StatisticBean'> 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}; </select>

編寫(xiě)service層就不再介紹了。

測(cè)試類(lèi)方法

@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()); }

可以成功輸出數(shù)據(jù)庫(kù)中的數(shù)據(jù),完成了我們的目的——統(tǒng)計(jì)。

4. 總結(jié)

重點(diǎn)了解一下as 的用法,as后面跟著的是實(shí)體類(lèi)的屬性名,當(dāng)然xml文件中一定要指明returnType是那個(gè)實(shí)體類(lèi),注意要寫(xiě)詳細(xì)的class地址。

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

補(bǔ)充知識(shí):mybatis 學(xué)習(xí)總結(jié)3 表字段與javabean字段的映射

有時(shí)候我們封裝的javabean與庫(kù)表的字段并不能一一對(duì)應(yīng),我們需要做一些必要的配置以保證數(shù)據(jù)能夠正確的獲取。

總的來(lái)說(shuō),解決庫(kù)表與javabean字段不統(tǒng)一的方法有以下幾種。

1.駝峰轉(zhuǎn)換

我們?cè)诜庋b實(shí)體類(lèi)的時(shí)候,通常將屬性命令為駝峰形式,例如

userName

而庫(kù)表的命名則遵循全小寫(xiě),多個(gè)單詞間使用 ’_’ 下劃線(xiàn)連接的方式, 例如

user_name

這種情況我們可以使用mybatis的駝峰轉(zhuǎn)換策略 在mybatis 的config.xml配置文件中 添加如下代碼:

<!--設(shè)置集標(biāo)簽--> <settings> <!--設(shè)置標(biāo)簽 === 駝峰轉(zhuǎn)換--> <setting name='mapUnderscoreToCamelCase' value='true'/> </settings>

添加如下策略后,針對(duì)查詢(xún)結(jié)果集中的字段出現(xiàn)上例中的沖突時(shí)則能夠得到解決。

2.sql語(yǔ)句中的 AS 關(guān)鍵字 — 起別名

我們?cè)跀?shù)據(jù)庫(kù)建一個(gè)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())

插入幾條數(shù)據(jù)

INSERT INTO course (course_name,grade,teacher_id) VALUES (’高等數(shù)學(xué)’,1,1);INSERT INTO course (course_name,grade,teacher_id) VALUES (’微積分’,2,2);INSERT INTO course (course_name,grade,teacher_id) VALUES (’希臘文學(xué)史’,3,3);

建立實(shí)體類(lèi)

@Alias('courseBO')public class CourseBO{private Long courseId; //數(shù)據(jù)庫(kù)-- idprivate String courseName; //數(shù)據(jù)庫(kù) -- course_nameprivate Integer courseGrade; //數(shù)據(jù)庫(kù) -- gradeprivate Long courseTeacherId; //數(shù)據(jù)庫(kù) -- teacher_idprivate Date addTime; //數(shù)據(jù)庫(kù) -- add_timeprivate Date modTime; //數(shù)據(jù)庫(kù) -- mod_time/*** 以下為 get set 方法 以及 toString 方法*/}

可以簡(jiǎn)單的發(fā)現(xiàn)幾個(gè)庫(kù)表與實(shí)體字段的不同

mapper.xml

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='mapping.CourseMapper'> <select resultType='Model.CourseBO'> SELECT * FROM course WHERE id = #{id} </select></mapper>

mapper接口

public interface CourseMapper extends BaseMapper { CourseBO getCourseByPriMaryKey(@Param('id') Long id);}

config.xml 注冊(cè)mapper

<!--映射注冊(cè) 加載映射文件--> <mappers> <!--第一種即第三種方法使用resource屬性注冊(cè)mapper,路徑為xml文件--> <mapper resource='resource/mapper/UserMapper.xml' /> <!--第二種方式即注解方式使用class屬性注冊(cè)mapper,路徑為接口class文件--> <!--<mapper />--> <mapper resource='resource/mapper/CourseMapper.xml' /> </mappers>

測(cè)試方法

public class FieldMappingDemo { public static void main(String[] args) throws IOException { String resource = 'resource/common/mybatis-config.xml'; InputStream in = Resources.getResourceAsStream(resource); SqlSession sqlSession= new SqlSessionFactoryBuilder().build(in).openSession(); CourseMapper courseMapper = sqlSession.getMapper(CourseMapper.class); CourseBO courseBO = courseMapper.getCourseByPriMaryKey(1L); System.out.println(courseBO); sqlSession.close(); }}

執(zhí)行結(jié)果

mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配

可以看到由于主鍵映射的失敗,整個(gè)結(jié)果對(duì)象返回為null

我們現(xiàn)在在sql語(yǔ)句中加入字段別名,同時(shí)設(shè)置駝峰轉(zhuǎn)換策略

<select resultType='Model.CourseBO'> SELECT id courseId, course_name, grade courseGrade, teacher_id courseTeacherId, add_time, mod_time FROM course WHERE id = #{id}</select>

<!--設(shè)置集標(biāo)簽--> <settings> <!--設(shè)置標(biāo)簽 === 駝峰轉(zhuǎn)換--> <setting name='mapUnderscoreToCamelCase' value='true'/> </settings>

再次執(zhí)行,結(jié)果:

mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配

可以看到數(shù)據(jù)正確的獲取到了。

3.resultMap建立字段映射

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

<!--id:唯一標(biāo)識(shí) type:JavaBean實(shí)體--> <resultMap type='Model.CourseBO'> <!--id標(biāo)簽為主鍵標(biāo)簽,resultMap中必須存在一個(gè)id標(biāo)簽--> <id column='id' jdbcType='BIGINT' property='courseId' javaType='Long' /> <!--result標(biāo)簽為屬性標(biāo)簽, column屬性指定表字段名,jdbcType為表字段數(shù)據(jù)類(lèi)型 property為實(shí)體屬性名,javaType為實(shí)體屬性數(shù)據(jù)類(lèi)型--> <result column='course_name' jdbcType='VARCHAR' property='courseName' javaType='String'/> <result column='grade' jdbcType='SMALLINT' property='courseGrade' javaType='Integer'/> <result column='teacher_id' jdbcType='BIGINT' property='courseTeacherId' javaType='Long'/> <result column='add_time' jdbcType='TIMESTAMP' property='addTime' javaType='Date'/> <result column='mod_time' jdbcType='TIMESTAMP' property='modTime' javaType='Date'/> </resultMap> <!--select標(biāo)簽的 resultMap 指定resultMap標(biāo)簽中的id 值--> <!--去掉所有的別名 --> <select resultMap='SqlMap'> SELECT * FROM course WHERE id = #{id} </select>

執(zhí)行結(jié)果

mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配

以上這篇mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
四虎成人精品一区二区免费网站| 久久国内精品视频| 麻豆精品视频在线观看免费| 日韩激情视频网站| 日韩国产欧美三级| 国产欧美精品| 国产精品igao视频网网址不卡日韩 | 国产精品麻豆成人av电影艾秋| 婷婷久久免费视频| 91麻豆精品激情在线观看最新| 亚洲在线电影| 综合欧美精品| 欧美日韩一区二区三区在线电影| 国产一卡不卡| 精品久久网站| 午夜精品成人av| 亚洲激情欧美| 日本成人手机在线| 欧美国产另类| 日韩欧美精品综合| 亚洲免费激情| 国产一区二区三区网| 国产在线日韩| 欧美不卡高清一区二区三区| 欧美国产极品| 精品亚洲自拍| 午夜国产欧美理论在线播放| 国产乱码精品| 蜜桃成人av| 国产精品激情电影| 日韩精品国产精品| 国产欧美日韩| 日韩大片在线| 五月激激激综合网色播| 久久精品国产亚洲夜色av网站 | 午夜精品网站| 国产日韩欧美三区| 欧美日韩在线二区| 亚洲精品无吗| 久久福利毛片| 青青久久av| а√天堂中文在线资源8| 日韩激情视频网站| 视频一区中文字幕精品| 国产v综合v| 成人污污视频| 精品国产亚洲一区二区三区在线| 免费观看久久av| 性感美女一区二区在线观看| 亚洲高清成人| 久久精品av麻豆的观看方式| 日本午夜大片a在线观看| 激情偷拍久久| 国产乱人伦丫前精品视频| 国产99久久久国产精品成人免费| 日韩精品国产精品| 欧产日产国产精品视频| 国产福利资源一区| 国产精品亚洲片在线播放| 亚洲激情中文| av日韩中文| 亚洲激情二区| 中文一区一区三区免费在线观| 日韩精品视频在线看| 欧美特黄一区| 免费看久久久| 久热re这里精品视频在线6| 国产美女久久| 欧美福利一区| 精品免费av一区二区三区| 亚洲欧美网站| 色综合五月天| 91成人精品观看| 亚洲男女av一区二区| 国产一区二区三区视频在线| 日韩一区二区三区免费视频| 99久久久久| 精品一区二区三区中文字幕视频| 视频在线观看一区| 激情久久久久久| 精品久久影院| 国产精品一线天粉嫩av| 久久午夜影视| 日韩av在线播放网址| 日本欧美一区| 国产精品毛片一区二区三区| 色一区二区三区| 国产精品一区毛片| 日韩精品欧美精品| 噜噜噜久久亚洲精品国产品小说| 亚洲人成在线网站| 久久只有精品| 亚洲精品一级二级三级| 国产精品女主播一区二区三区| 日韩在线高清| 91欧美国产| 美女久久精品| 国产欧美日韩在线一区二区 | 日韩精品a在线观看91| 中文字幕在线视频久| 免费在线成人网| 91精品蜜臀一区二区三区在线| 蜜臀av一区二区三区| 国产综合视频| 日韩一区自拍| 99久久久国产精品美女| 日本不良网站在线观看| 久久久久久久欧美精品| 亚洲有吗中文字幕| 精品国产91| 久久亚洲道色| 国产日韩欧美| 午夜电影一区| 亚州av一区| 玖玖玖国产精品| 女人天堂亚洲aⅴ在线观看| 欧美日韩精品一本二本三本| 老牛国内精品亚洲成av人片| 国产欧美日韩免费观看| 日本亚洲欧洲无免费码在线| 亚洲欧美日韩综合国产aⅴ| 丝袜美腿高跟呻吟高潮一区| 国产午夜精品一区二区三区欧美| 日韩av中文字幕一区二区三区| 久久免费精品| 久久午夜影视| 一区二区三区国产在线| 综合五月婷婷| 亚洲va久久| 日韩av一二三| 欧美a一区二区| 91精品福利观看| 国产精品一页| 精品一区二区三区中文字幕| 国产suv精品一区| 欧洲亚洲一区二区三区| 欧美成人日韩| 综合激情一区| 91p九色成人| 久久中文精品| 日韩精品看片| 国产亚洲精品v| 日本v片在线高清不卡在线观看| 日韩黄色在线观看| 国产乱人伦精品一区| 福利一区二区免费视频| 国产一区二区三区不卡av| a国产在线视频| 久久精品99久久无色码中文字幕| 最新日韩欧美| 日韩和欧美一区二区| 免费看久久久| 99久久九九| 一区二区三区国产在线| 国产精品伊人| 日本精品影院| 中文字幕一区二区三区在线视频| 国产日本亚洲| 中文在线а√天堂| 国产亚洲高清视频| 国产欧美激情| 福利一区和二区| 亚洲高清影视| 久久精品中文| 欧美日中文字幕| 久久久久国产精品一区三寸 | 樱桃视频成人在线观看| 丝袜亚洲另类欧美| 午夜欧美精品久久久久久久| 日韩精品午夜| 日韩国产一区二区三区| 国产videos久久| 国产成人精品一区二区三区在线| 中文久久精品| 成人久久一区| 国产日产高清欧美一区二区三区| 日韩激情中文字幕| 国产日本久久| 色婷婷成人网| 肉色欧美久久久久久久免费看 | 久久黄色影院| 日韩一区二区三区精品视频第3页| 深夜福利亚洲| 婷婷中文字幕一区| 精品国产一区二区三区噜噜噜| 国产精品伦一区二区| 自拍日韩欧美| 国产精品免费不| 日韩欧美2区| 国产精品22p| 精品免费在线| 97精品国产福利一区二区三区| 欧美sss在线视频| 日韩在线观看不卡| 国产免费av国片精品草莓男男| 亚洲一区久久| 国产精一区二区| 蜜桃av一区| 久久天堂av| 国产精品久久久网站|