No operator matches the given name and argument type(s). You might need to add explicit type casts报错

2023-11-01 15:50

本文主要是介绍No operator matches the given name and argument type(s). You might need to add explicit type casts报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、报错信息:

PostgreSQL下数据类型转化报错:No operator matches the given name and argument type(s). You might need to add explicit type casts报错。
正式环境,出现如下问题:

在这里插入图片描述
但是公司内网测试环境竟然没有报错(离大谱)!!
在这里插入图片描述

二、出现问题原因为:

数据库字段中使用int2,参数类型为String,此时就会报 character varying = bigint错误。

三、解决方案:
(1)修改代码参数类型

有人就直接修改了代码参数类型,修改接口参数即可,然后再使用jenkins构建发布,幸运的话就直接解决问题了,倘如项目有很多诸如类似的问题,全局搜索后绝望无比。。。

(2)使用强转函数
那么有的人说不想修改参数怎么办,另一种方式就是修改xml中表的字段。
在这里插入图片描述

(3)创建新的类型转换

那么又有人说,我没有使用xml写sql语句,使用的注解方式(复杂sql不建议使用注解方式)或者说字段太多一个个修改效率太低怎么办?就不能像MySQL和Oracle那样默认对数据类型进行转换吗?
pg确实没有实现数据类型的自动转换,但是!pg官方文档中也给出了相应处理方式,可以设置自定义的数据类型转换。如下:(创建类型转换需要注意以下描述)
①创建类型转换:

CREATE CAST (INTEGER AS VARCHAR) WITH INOUT AS IMPLICIT;
CREATE CAST (VARCHAR AS INTEGER) WITH INOUT AS IMPLICIT;
CREATE CAST (BIGINT AS VARCHAR) WITH INOUT AS IMPLICIT;
CREATE CAST (VARCHAR AS BIGINT) WITH INOUT AS IMPLICIT;

–注:创建cast需要有pg_cast系统表的权限
–注:当创建类型转换使用自动隐式转换的话如果出现多个匹配的转换此时pg会因为不知道选择哪一个去处理类型转换而报错。
–如果出现多个隐式自动转换都匹配此时还是需要手动添加转换以达到效果,或者删除多余的类型转换。在这里插入图片描述

这样我们就解决了上述又不想修改参数,也不想修改xml字段类型的问题。

②查询已存在的转换类型:

SELECT( SELECT typname FROM pg_type WHERE oid = T.castsource ) AS “ castsource”,( SELECT typname FROM pg_type WHERE oid = T.casttarget ) AS “ casttarget”,castcontext,castmethod 
FROMpg_cast AS T

③删除已存在转换类型:

DROP CAST (varchar as bigint);
DROP CAST (bigint as varchar);

上述解决办法适用于一直在pg数据库环境下开发的项目。
四、总结:
开发人员一定要规范开发代码,虽然说有的数据库(指MySQL或Oracle)会给我们优化掉,但是类型还是严格对应,不过PostgregSQL确实和其他两个热门数据库比较还是有很多区别点,开发时需要特别注意,详细区别可见另一篇文章:
《PostgreSQL和MySQL的区别》

在这里插入图片描述

这篇关于No operator matches the given name and argument type(s). You might need to add explicit type casts报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/324084

相关文章

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

Python报错ModuleNotFoundError的10种解决方案

《Python报错ModuleNotFoundError的10种解决方案》在Python开发中,ModuleNotFoundError是最常见的运行时错误之一,通常由模块路径配置错误、依赖缺失或命名冲... 目录一、常见错误场景与原因分析二、10种解决方案与代码示例1. 检查并安装缺失模块2. 动态添加模块

idea报错java: 非法字符: ‘\ufeff‘的解决步骤以及说明

《idea报错java:非法字符:‘ufeff‘的解决步骤以及说明》:本文主要介绍idea报错java:非法字符:ufeff的解决步骤以及说明,文章详细解释了为什么在Java中会出现uf... 目录BOM是什么?1. BOM的作用2. 为什么会出现 \ufeff 错误?3. 如何解决 \ufeff 问题?最

解决Maven项目报错:failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题

《解决Maven项目报错:failedtoexecutegoalorg.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题》这篇文章主要介... 目录Maven项目报错:failed to execute goal org.apache.maven.pl

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二: