Oracle?ORA-00904:标识符无效解决方法(太坑了!!)(ora 00904 标识符无效)满满干货

随心笔谈2年前发布 编辑
180 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



目录问题描述原因分析:解决方案:总结

ORA-00904:标识符无效 解决办法(Oracle字段名区分大小写的坑)

我在使用jpa或者mybatis集成Oracle进行where查询的时候发现一直出现:

java.sql.SQLSyntaxErrorException: ORA-00904: “USER0_”.“PWD”: 标识符无效

下面是问题代码:

@Test
void test01(){
User user=userDao.findByPwd(“ccat”);
System.out.println(“user=” + user);
}

再来看看我的dao层代码块和实体代码块

数据接口的设计如下图

在这里我们可以看到整体的代码逻辑是没有问题的,但是再看看数据表结构发现: 字段为小写,其实PL自动生成的创建表的脚本中,表名和字段名都加了双引号。双引号在Oracle中表示区分大小写,Oracle是严格区分大小写的,未使用双引号时默认全部大写。可能很多人都会误认为oracle是不区分大小写的,原因是我们在写查询语句的时候,大小写无所谓,结果都是一样的,这只是个表面现象,只要你不使用双引号表示区分大小写,oracle会默认把你写的脚本全部转换为大写的。

下面是问题代码:到这里大家我想大家应该明白了,怎么使Oracle区分大小写了,就是使用双引号。

1.将数据表中的字段名改为大写。

2.经过网上的一番查找,正如上面所讲,如果我们不加双引号,那么Oracle会默认把表名和字段名全部转换为大写形式。

最简单的查询语句:SELECT *

FROM t_user

WHERE “pwd”=‘ccat’;

这样我们就能查出想要的数据啦。

到此这篇关于Oracle ORA-00904:标识符无效解决的文章就介绍到这了,更多相关ORA-00904:标识符无效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:Oracle实例启动时报错:ORA-32004的解决方法Linux中Oracle启动侦听报错TNS:permission denied的解决方法Oracle还原恢复启动时数据库报ORA-00704、 ORA-00604,、ORA-00904的问题解决

© 版权声明

相关文章