java.sql.SQLSyntaxErrorException: ORA-00909: 参数个数无效

问题:

在@Select里采用Contact('%',#name,'%')报错参数个数无效

原因:

回想以前用Mysql的时候就是这样用的,没有问题,在这里就出问题了,所以确定问题在oracle数据库上,经过查询得知,oracle和mysql的concat函数不太一样。

一、函数的使用参数不同

Mysql支持多个字符串拼接:

CONCAT(str1,str2,...)

Oralce只支持两个字符串的拼接,若想拼接多个字符串可以嵌套使用concat

CONCAT(str1,str2)

二、参数中有Null的处理方式不同

Mysql:返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。

Oralce:如有任何一个参数为NULL ,则返回值拼接后的字符串。

三、其它方面

Mysql:如果所有参数均为非二进制字符串,则结果为非二进制字符串。

如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。

Oracle:如果CONCAT中连接的值不是字符串,Oracle会尝试将其转换为字符串

注:Oracle拼接字符串还可以使用"||",当参数为Null时,返回值拼接后的字符串。

解决:

a.name like concat('%',#{name},'%')  改成  a.name like concat(concat('%',#{name}),'%')

相关推荐
SimonKing几秒前
短信被截断?5分钟用Java打造企业级短链服务
java·后端·架构
XuanXu2 分钟前
SpringBoot3.0启动流程研究
java·spring boot
加点油。。。。32 分钟前
Matlab绘图(三)——设置图例的位置
开发语言·matlab·绘图
硬匠的博客35 分钟前
C/C++指针
c语言·开发语言·c++
向日葵.1 小时前
CMake学习
开发语言·c++·学习
hp.puppy1 小时前
kali下maven 的安装与配置
java·maven
碎梦归途1 小时前
23种设计模式-创建型模式之工厂方法模式(Java版本)
java·设计模式·工厂方法模式
放情1 小时前
关于k8s的部署
java·docker·kubernetes
August_._1 小时前
【JavaWeb】详细讲解 HTTP 协议
java·网络·网络协议·http
zru_96021 小时前
Java Stream流之GroupBy的用法
java·开发语言