Oracle?ORA-00904:標(biāo)識(shí)符無(wú)效解決方法(太坑了!!)
ORA-00904:標(biāo)識(shí)符無(wú)效 解決辦法(Oracle字段名區(qū)分大小寫的坑)
問(wèn)題描述
我在使用jpa或者mybatis集成Oracle進(jìn)行where查詢的時(shí)候發(fā)現(xiàn)一直出現(xiàn):
java.sql.SQLSyntaxErrorException: ORA-00904: “USER0_”.“PWD”: 標(biāo)識(shí)符無(wú)效
下面是問(wèn)題代碼:
@Test
void test01(){
User user = userDao.findByPwd("ccat");
System.out.println("user = " + user);
}
再來(lái)看看我的dao層代碼塊和實(shí)體代碼塊


數(shù)據(jù)接口的設(shè)計(jì)如下圖

原因分析:
在這里我們可以看到整體的代碼邏輯是沒(méi)有問(wèn)題的,但是再看看數(shù)據(jù)表結(jié)構(gòu)發(fā)現(xiàn):pwd 字段為小寫,其實(shí)PL自動(dòng)生成的創(chuàng)建表的腳本中,表名和字段名都加了雙引號(hào)。雙引號(hào)在Oracle中表示區(qū)分大小寫,Oracle是嚴(yán)格區(qū)分大小寫的,未使用雙引號(hào)時(shí)默認(rèn)全部大寫??赡芎芏嗳硕紩?huì)誤認(rèn)為oracle是不區(qū)分大小寫的,原因是我們?cè)趯懖樵冋Z(yǔ)句的時(shí)候,大小寫無(wú)所謂,結(jié)果都是一樣的,這只是個(gè)表面現(xiàn)象,只要你不使用雙引號(hào)表示區(qū)分大小寫,oracle會(huì)默認(rèn)把你寫的腳本全部轉(zhuǎn)換為大寫的。
解決方案:
下面是問(wèn)題代碼:到這里大家我想大家應(yīng)該明白了,怎么使Oracle區(qū)分大小寫了,就是使用雙引號(hào)。
1.將數(shù)據(jù)表中的字段名改為大寫。
2.經(jīng)過(guò)網(wǎng)上的一番查找,正如上面所講,如果我們不加雙引號(hào),那么Oracle會(huì)默認(rèn)把表名和字段名全部轉(zhuǎn)換為大寫形式。
最簡(jiǎn)單的查詢語(yǔ)句:SELECT *
FROM t_user
WHERE “pwd” =‘ccat’;

這樣我們就能查出想要的數(shù)據(jù)啦。
總結(jié)
到此這篇關(guān)于Oracle ORA-00904:標(biāo)識(shí)符無(wú)效解決的文章就介紹到這了,更多相關(guān)ORA-00904:標(biāo)識(shí)符無(wú)效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- PL/SQL登錄Oracle數(shù)據(jù)庫(kù)報(bào)錯(cuò)ORA-12154:TNS:無(wú)法解析指定的連接標(biāo)識(shí)符已解決(本地未安裝Oracle需要連接服務(wù)器上的)
- Oracle報(bào)存儲(chǔ)過(guò)程中調(diào)用DBLink同義詞出現(xiàn)錯(cuò)誤:PLS-00201: 必須聲明標(biāo)識(shí)符
- Oracle出現(xiàn)ora-12154無(wú)法解析指定連接標(biāo)識(shí)符的解決方法
- Oracle連接出現(xiàn)ora-12154無(wú)法解析指定的連接標(biāo)識(shí)符
- Oracle導(dǎo)dmp出現(xiàn)文件ORA-12154: TNS: 無(wú)法解析指定的連接標(biāo)識(shí)符問(wèn)題的解決方案
- 使用oracle發(fā)生標(biāo)識(shí)符無(wú)效問(wèn)題及解決
相關(guān)文章
Oracle數(shù)據(jù)回退的實(shí)現(xiàn)
在使用plsql工具,對(duì)表數(shù)據(jù)進(jìn)行操作后,提交了事務(wù),發(fā)現(xiàn)數(shù)據(jù)更新或者刪除錯(cuò)了,這時(shí)候還是有方法可以把數(shù)據(jù)回退的,本文就詳細(xì)的介紹此方法,感興趣的可以了解一下2023-08-08
基于ORA-12170 TNS 連接超時(shí)解決辦法詳解
本篇文章是對(duì)ORA-12170 TNS 連接超時(shí)的解決辦法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
oracle與gbase8s遷移數(shù)據(jù)類型對(duì)照以及舉例說(shuō)明
gbase8s是一個(gè)高性能的分布式關(guān)系型數(shù)據(jù)庫(kù),下面這篇文章主要給大家介紹了關(guān)于oracle與gbase8s遷移數(shù)據(jù)類型對(duì)照以及舉例說(shuō)明的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
PLSQL創(chuàng)建新用戶并導(dǎo)入導(dǎo)出.dmp文件全過(guò)程
plsql導(dǎo)入.sql和.dmp文件時(shí)會(huì)經(jīng)常用到,對(duì)于初學(xué)者來(lái)說(shuō)可能沒(méi)有那么簡(jiǎn)單,畢竟oracle數(shù)據(jù)庫(kù)比較麻煩,這篇文章主要給大家介紹了關(guān)于PLSQL創(chuàng)建新用戶并導(dǎo)入導(dǎo)出.dmp文件的相關(guān)資料,需要的朋友可以參考下2023-11-11
Oracle中 關(guān)于數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)的使用
本篇文章,小編將為大家介紹,在Oracle中 關(guān)于數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)的使用,有需要的朋友可以參考一下2013-04-04
Oracle數(shù)據(jù)庫(kù)閃回功能詳解和相關(guān)命令總結(jié)
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)閃回功能詳解和相關(guān)命令總結(jié)的相關(guān)資料,閃回技術(shù)(Flashback),是Oracle提供的能使數(shù)據(jù)庫(kù)整體或局部回到"過(guò)去"的閃回功能的總稱,主要用于對(duì)抗人為錯(cuò)誤,需要的朋友可以參考下2023-07-07
Oracle查詢當(dāng)前的crs/has自啟動(dòng)狀態(tài)實(shí)例教程
當(dāng)我們開(kāi)啟或者關(guān)閉自啟動(dòng)后,我們?nèi)绾尾榭串?dāng)前CRS 是處于enable還是處于disable中呢?下面這篇文章主要給大家介紹了關(guān)于Oracle如何查詢當(dāng)前的crs/has自啟動(dòng)狀態(tài)的相關(guān)資料,需要的朋友可以參考下2018-11-11
Oracle ASM故障數(shù)據(jù)恢復(fù)解決方案
在本篇文章里小編給大家整理的是關(guān)于Oracle ASM故障數(shù)據(jù)恢復(fù)解決方案以及相關(guān)知識(shí)點(diǎn),有需要的朋友們參考下。2019-11-11

