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

 更新时间:2022年10月25日 11:09:53   作者:不会秃头的_图图  
最近执行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数据回退的实现

    Oracle数据回退的实现

    在使用plsql工具,对表数据进行操作后,提交了事务,发现数据更新或者删除错了,这时候还是有方法可以把数据回退的,本文就详细的介绍此方法,感兴趣的可以了解一下
    2023-08-08
  • 基于ORA-12170 TNS 连接超时解决办法详解

    基于ORA-12170 TNS 连接超时解决办法详解

    本篇文章是对ORA-12170 TNS 连接超时的解决办法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL安全性指南(3)(转)

    MySQL安全性指南(3)(转)

    MySQL安全性指南(3)(转)...
    2007-03-03
  • oracle与gbase8s迁移数据类型对照以及举例说明

    oracle与gbase8s迁移数据类型对照以及举例说明

    gbase8s是一个高性能的分布式关系型数据库,下面这篇文章主要给大家介绍了关于oracle与gbase8s迁移数据类型对照以及举例说明的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • PLSQL创建新用户并导入导出.dmp文件全过程

    PLSQL创建新用户并导入导出.dmp文件全过程

    plsql导入.sql和.dmp文件时会经常用到,对于初学者来说可能没有那么简单,毕竟oracle数据库比较麻烦,这篇文章主要给大家介绍了关于PLSQL创建新用户并导入导出.dmp文件的相关资料,需要的朋友可以参考下
    2023-11-11
  • Oracle中 关于数据库存储过程和存储函数的使用

    Oracle中 关于数据库存储过程和存储函数的使用

    本篇文章,小编将为大家介绍,在Oracle中 关于数据库存储过程和存储函数的使用,有需要的朋友可以参考一下
    2013-04-04
  • Oracle数据库闪回功能详解和相关命令总结

    Oracle数据库闪回功能详解和相关命令总结

    这篇文章主要给大家介绍了关于Oracle数据库闪回功能详解和相关命令总结的相关资料,闪回技术(Flashback),是Oracle提供的能使数据库整体或局部回到"过去"的闪回功能的总称,主要用于对抗人为错误,需要的朋友可以参考下
    2023-07-07
  • Oracle查询当前的crs/has自启动状态实例教程

    Oracle查询当前的crs/has自启动状态实例教程

    当我们开启或者关闭自启动后,我们如何查看当前CRS 是处于enable还是处于disable中呢?下面这篇文章主要给大家介绍了关于Oracle如何查询当前的crs/has自启动状态的相关资料,需要的朋友可以参考下
    2018-11-11
  • Oracle ASM故障数据恢复解决方案

    Oracle ASM故障数据恢复解决方案

    在本篇文章里小编给大家整理的是关于Oracle ASM故障数据恢复解决方案以及相关知识点,有需要的朋友们参考下。
    2019-11-11
  • Oracle分页查询的实例详解

    Oracle分页查询的实例详解

    这篇文章主要介绍了Oracle分页查询的实例详解的相关资料,希望通过本文能帮助到大家实现理解这部分内容,需要的朋友可以参考下
    2017-10-10

最新评论