加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘南站长网 (https://www.0941zz.com/)- 科技、行业物联网、开发、云计算、云管理!
当前位置: 首页 > 数据库 > Oracle > 正文

ORA-00904 标识符无效 太坑了

发布时间:2023-02-17 09:14:31 所属栏目:Oracle 来源:互联网
导读:ORA-00904:标识符无效 解决办法(Oracle字段名区分大小写的坑) 问题描述 我在使用jpa或者mybatis集成Oracle进行where查询的时候发现一直出现: java.sql.sqlSyntaxErrorException: ORA-00904: USER0_.PWD: 标识符无效 下面是问题代码: @Test void test01(){
  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’;
 
  在这里插入图片描述
 
 
  这样我们就能查出想要的数据啦。
 

(编辑:甘南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读