我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mybatisgroupbysubstr函数传参报错的解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mybatisgroupbysubstr函数传参报错的解决

mybatis group by substr传参报错

报异常

### Cause: java.sql.SQLSyntaxErrorException: ORA-00979: 不是 GROUP BY 表达式

SELECT
    SUBSTR( region_code, 1,#{ queryMap.groupCodeLength, jdbcType = INTEGER } ) AS "region_code",
    count( CASE WHEN TYPE = 1 THEN 0 END ) AS "like",
    count( CASE WHEN TYPE = 2 THEN 0 END ) AS "roast" 
FROM
    t_pub_sentiment 
WHERE
    1 = 1 
GROUP BY
    SUBSTR(region_code,1,#{ queryMap.groupCodeLength,jdbcType = INTEGER })

更改后:

SELECT
    SUBSTR( region_code, 1, $ { queryMap.groupCodeLength } ) AS "region_code",
    count( CASE WHEN TYPE = 1 THEN 0 END ) AS "like",
    count( CASE WHEN TYPE = 2 THEN 0 END ) AS "roast" 
FROM
    t_pub_sentiment 
WHERE
    1 = 1 
GROUP BY
    SUBSTR( region_code, 1, $ { queryMap.groupCodeLength } )

原因

#{} 和 ${} 在预编译中的处理是不一样的。#{} 在预处理时,会把参数部分用一个占位符 ? 代替。而 ${} 则只是简单的字符串替换。

${}有sql注入的风险,需谨慎使用。

使用group by 分组查询返回为null

我在使用mybatis进行分组查询时数据库有数据,但是mybatis返回为null,使用mybatis版本为3.4.1

解决方法

在resultMap的result标签中添加 property属性

如下:

<resultMap id="deptMap" type="java.util.Map">
        <result column="id" property="id"/>
        <result column="dept_name" property="deptname"/>
        <result column="count(1)" property="count"/>
    </resultMap>
  
 <select id="getDeptByIdStep" resultMap="deptMap">
  select  id,dept_name,count(1)  from tbl_dept where dept_id=#{id} group by id;
 </select>

我在第一次使用时没有添加property导致mybatis返回null,添加后就可以正常返回。

dao层代码

public List<Map> getDeptByIdStep(Integer id);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mybatisgroupbysubstr函数传参报错的解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mybatis group by substr函数传参报错怎么解决

这篇文章主要介绍“mybatis group by substr函数传参报错怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis group by substr函数传参报错怎么解决”
2023-06-28

如何解决使用@PathVariable传递参数报错404的问题

这篇文章给大家分享的是有关如何解决使用@PathVariable传递参数报错404的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。目录@PathVariable传递参数报错404restFul风格传参, 参数
2023-06-25

C++ 函数参数详解:高阶函数中参数传递的范例

c++++ 中有两种参数传递机制:传值传递和传址传递。传址传递将对象的内存地址传递给函数,而传值传递将值的副本传递给函数。高阶函数是接受函数作为参数的函数,其参数传递需要特别注意,因为传递的函数可能具有不同的参数签名和返回类型。示例中,st
C++ 函数参数详解:高阶函数中参数传递的范例
2024-04-27

C++ 函数参数详解:函数重载中参数传递的影响

在 c++++ 函数重载中,函数参数的传递方式会影响函数重载的行为。影响如下:1. 传值:只关心参数数量和顺序;2. 传引用:考虑参数类型;3. 传指针:不考虑参数类型。实战中,理解传递方式对于正确重载函数至关重要,如上述 print()
C++ 函数参数详解:函数重载中参数传递的影响
2024-04-27

C++ 函数参数详解:函数式编程中参数传递的思想

c++++ 函数中参数传递有五种方式:引用传递、值传递、隐式类型转换、const 参数、默认参数。引用传递提高效率,值传递更安全;隐式类型转换自动将其他类型转换为函数期望的类型;const 参数防止意外修改;默认参数允许省略某些参数。在函数
C++ 函数参数详解:函数式编程中参数传递的思想
2024-04-28

高防上传HTTPS证书出现“参数格式错误”报错的解决办法

这篇文章给大家介绍高防上传HTTPS证书出现“参数格式错误”报错的解决办法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。高防上传HTTPS证书时出现“参数错误”的常见原因有下面三种:1.证书名字过长请修改证书文件名为1
2023-06-04

php scandir函数报错怎么解决

如果PHP的scandir函数报错,可能是因为以下几个原因:权限问题:确保要扫描的目录具有适当的权限,PHP脚本具有读取目录的权限。目录不存在:检查要扫描的目录是否存在,确保路径是正确的。内存问题:如果要扫描的目录中包含大量文件,可能会导致
php scandir函数报错怎么解决
2024-03-11

golang函数通过管道传递参数的详解

在 go 中,可以将函数作为参数通过管道传递,实现步骤如下:定义接收函数的 goroutine。在调用端 goroutine 中,创建管道并向其发送函数。Go 中通过管道传递函数参数在 Go 中,管道是一种用于进程间通信(IPC)的并发机
golang函数通过管道传递参数的详解
2024-05-05

sql isnull函数报错怎么解决

在SQL中,ISNULL函数用于判断一个表达式是否为NULL,并在其为NULL时返回指定的值。如果ISNULL函数报错,可能是因为以下原因:函数名称不正确:确保使用的是正确的函数名称,ISNULL函数在不同的数据库系统中可能有不同的名称,如
sql isnull函数报错怎么解决
2024-04-09

C++ 函数参数详解:协程中参数传递的异步机制

协程中参数传递采用异步机制,不会在执行前复制参数值,而是动态获取。这种机制提供了灵活性,允许协程在运行时调整参数或延迟传递参数。具体步骤如下:传统函数参数传递:同步传递,函数执行前将实参复制到局部变量。协程参数传递:异步传递,协程使用协程指
C++ 函数参数详解:协程中参数传递的异步机制
2024-04-26

解决PHP中explode函数报错的方法

解决PHP中explode函数报错的方法,需要具体代码示例在PHP中,explode函数是用于将字符串按照指定的分隔符拆分成数组的函数。然而,有时候在使用explode函数时会出现报错的情况,主要是因为传入的参数不符合函数的要求所导致的。
解决PHP中explode函数报错的方法
2024-03-11

C++ 函数参数详解:lambda表达式中参数传递的规则

lambda 表达式中的参数传递规则:by value:按值传递,对原始值的修改不影响外部作用域。by reference:使用 [&] 或 [=] 捕获列表按引用传递参数,允许修改外部作用域。by move:对于可移动类型,使用 && 捕
C++ 函数参数详解:lambda表达式中参数传递的规则
2024-04-26

C++ 函数参数的传递方式详解:值传递和引用传递

c++++ 参数传递方式分为值传递和引用传递。值传递创建函数参数副本,不影响原变量;引用传递直接操作原变量。选择方式取决于需求:保护原变量使用值传递,修改原变量或提高效率使用引用传递。C++ 函数参数的传递方式详解:值传递和引用传递在 C
C++ 函数参数的传递方式详解:值传递和引用传递
2024-04-12

C++ 函数参数详解:泛型编程中参数传递的多态性

泛型编程中 c++++ 函数参数的多态性泛型函数的参数可以采用不同类型(参数传递的多态性),实现针对不同数据类型工作的灵活代码。参数传递方式有三种:值传递:副本传递,不会影响原始参数引用传递:引用传递,反映原始参数的更改指针传递:指针传递,
C++ 函数参数详解:泛型编程中参数传递的多态性
2024-04-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录