电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Mybatis返回結果封裝map過程解析

瀏覽:3日期:2023-10-22 16:26:49

需求

根據課程id 列表,查詢每個課程id的總數,放到一個map里

最簡單的就是循環遍歷,每一個都查詢一次

網上說mybatis可以返回Map 和 List<Map>兩種類型

嘗試

直接返回Map類型

<select resultType='java.util.HashMap'> SELECT course_id, count(1) FROM lesson WHERE status = 0 GROUP BY course_id;</select>

返回的結果是:

{'course_id':2,'count(1)':13}

即便我的數據庫里有很過個id,返回結果也只有這一條數據。

如果直接使用 Map<Long, Integer> 類型強轉,會報錯

Could not write JSON: java.lang.String cannot be cast to java.lang.Number; nested exception is com.fasterxml.jackson.databind.JsonMappingException: java.lang.String cannot be cast to java.lang.Number

所以是不能直接返回Map的,而是先返回List<Map>

最終實現

Dao 類中

List<HashMap<String,Object>> listLessonSumByCourseIdList();

Mapper.xml 中

<select resultType='java.util.HashMap'> SELECT course_id as ’key’, count(1) as ’value’ FROM lesson WHERE type != 1 AND status = 0 GROUP BY course_id;</select>

ServerImpl 中, 將List<Map> 轉成 Map

public Map<Long, Long> listLessonSumByCourseIdList() { Map<Long, Long> map = new HashMap<>(); List<HashMap<String, Object>> list = courseDao.listLessonSumByCourseIdList(); if (list != null && !list.isEmpty()) { for (HashMap<String, Object> map1 : list) { Long key = null; Long value = null; for (Map.Entry<String, Object> entry : map1.entrySet()) { if ('key'.equals(entry.getKey())) { key = (Long) entry.getValue(); } else if ('value'.equals(entry.getKey())) { value = (Long) entry.getValue(); } } map.put(key, value); } } return map;}

PS:count(1) 數據庫中查詢這個默認是Long類型,轉Integer會報錯,所以返回類型是Map<Long, Long>,而不能是Map<Long, Integer>java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.Integer

PPS:但是通過這種方法查詢出的數據有一些問題,如果我們想要的數據是,即便沒有值,也應該返回0,那么就不能通過這種方法了,這種方法如果查詢不到是沒有值的,還是老老實實的循環吧

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 不锈钢监控杆_监控立杆厂家-廊坊耀星光电科技有限公司 | 冷库安装厂家_杭州冷库_保鲜库建设-浙江克冷制冷设备有限公司 | 传递窗_超净|洁净工作台_高效过滤器-传递窗厂家广州梓净公司 | 一礼通 (www.yilitong.com)-企业礼品解决方案一站式服务平台 | 气胀轴|气涨轴|安全夹头|安全卡盘|伺服纠偏系统厂家-天机传动 | Copeland/谷轮压缩机,谷轮半封闭压缩机,谷轮涡旋压缩机,型号规格,技术参数,尺寸图片,价格经销商 CTP磁天平|小电容测量仪|阴阳极极化_双液系沸点测定仪|dsj电渗实验装置-南京桑力电子设备厂 | uv固化机-丝印uv机-工业烤箱-五金蚀刻机-分拣输送机 - 保定市丰辉机械设备制造有限公司 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 最新范文网_实用的精品范文美文网 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 品牌策划-品牌设计-济南之式传媒广告有限公司官网-提供品牌整合丨影视创意丨公关活动丨数字营销丨自媒体运营丨数字营销 | 结晶点测定仪-润滑脂滴点测定仪-大连煜烁| 手板_手板模型制作_cnc手板加工厂-东莞天泓 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 山东风淋室_201/304不锈钢风淋室净化设备厂家-盛之源风淋室厂家 翻斗式矿车|固定式矿车|曲轨侧卸式矿车|梭式矿车|矿车配件-山东卓力矿车生产厂家 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 科研ELISA试剂盒,酶联免疫检测试剂盒,昆虫_植物ELISA酶免试剂盒-上海仁捷生物科技有限公司 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 温州食堂承包 - 温州市尚膳餐饮管理有限公司 | CE认证_产品欧盟ROHS-REACH检测机构-商通检测 | 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | 氢氧化钙设备, 氢氧化钙生产线-淄博惠琛工贸有限公司 | 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 拉伸膜,PE缠绕膜,打包带,封箱胶带,包装膜厂家-东莞宏展包装 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 耐高温硅酸铝板-硅酸铝棉保温施工|亿欧建设工程 | 哈希PC1R1A,哈希CA9300,哈希SC4500-上海鑫嵩实业有限公司 | 智慧食堂_食堂管理系统_食堂订餐_食堂消费系统—客易捷 | 四合院设计_四合院装修_四合院会所设计-四合院古建设计与建造中心1 | 寮步纸箱厂_东莞纸箱厂 _东莞纸箱加工厂-东莞市寮步恒辉纸制品厂 | 考试试题_试卷及答案_诗词单词成语 - 优易学 | 数显恒温油浴-电砂浴-高温油浴振荡器-常州迈科诺仪器有限公司 | 艺术涂料|木纹漆施工|稻草漆厂家|马来漆|石桦奴|水泥漆|选加河南天工涂料 | 防堵吹扫装置-防堵风压测量装置-电动操作显示器-兴洲仪器 | 石英陶瓷,石英坩埚,二氧化硅陶瓷-淄博百特高新材料有限公司 | (中山|佛山|江门)环氧地坪漆,停车场地板漆,车库地板漆,聚氨酯地板漆-中山永旺地坪漆厂家 | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? |