首页 > 数据库 > oracle > ORA-00904:标识符无效

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

作者:不会秃头的_图图

最近执行sql时oracle报错ORA-00904:标识符无效,所以这篇文章主要给大家介绍了关于Oracle ORA-00904:标识符无效解决方法的相关资料,需要的朋友可以参考下

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层代码块和实体代码块

数据接口的设计如下图

原因分析:

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

解决方案:

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

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

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

最简单的查询语句:SELECT *
FROM t_user
WHERE “pwd” =‘ccat’;

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

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

您可能感兴趣的文章:
  • ORACLE创建DBlink的过程及使用方法
    ORACLE创建DBlink的过程及使用方法
    2023-06-06
  • Oracle单行函数(字符,数值,日期,转换)
    Oracle单行函数(字符,数值,日期,转换)
    2023-07-07
  • 关于oracle逻辑备份exp导出指定表名时需要加括号的问题解析
    关于oracle逻辑备份exp导出指定表名时需要加括号的问题解析
    2023-04-04
  • Oracle数据迁移MySQL的三种简单方法
    Oracle数据迁移MySQL的三种简单方法
    2023-06-06
  • Oracle管道函数pipelined function的用法小结
    Oracle管道函数pipelined function的用法小结
    2023-06-06
  • Oracle中instr函数与substr函数及自制分割函数详解
    Oracle中instr函数与substr函数及自制分割函数详解
    2023-06-06
  • oracle实现将字段按逗号拼接/按逗号分为多行实例代码
    oracle实现将字段按逗号拼接/按逗号分为多行实例代码
    2023-06-06
  • oracle扩展表空间方法示例
    oracle扩展表空间方法示例
    2023-06-06
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2023 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号