07 ORA系列:ORA-01747 或列说明无效 user.table.column, table.column
如果希望對常見的Oracle異常ORA報錯解決方案有系統的了解,請看《ORACLE系列異常總結ORA》。
?
1.通常錯誤原因
表中字段名稱與數據庫中關鍵名稱沖突了。
比如:
表中字段名稱為role,date, level等來表示角色,日期,級別
這與數據庫中的關鍵詞ROLE,DATE沖突了。
?
2.查詢表中字段名稱是否與數據庫關鍵次沖突SQL
| select?* from?v$reserved_words ?where?keyword in?( ?????????? ???select?COLUMN_NAME from?all_tab_columns ????where?table_name = '表名大寫'?and?owner = '用戶名大寫'); |
?
3.解決方案
3.1 避免使用ORACLE的關鍵字作為表字段名。(推薦)
3.2 建表時,把字段名加上雙引號,并且嚴格區分大小寫。因為Oracle默認是不區分大小寫的,但若是字符串,并使用了雙引號,此時會區分大小寫。默認情況date不能作為字段名稱,但使用雙引號后就可以創建表了。如下所示:
| create?table?test_person( pid varchar2(44) primary?key, pname varchar2(100), "date" date ); |
?
4.在框架中可能情況
在框架中配置引發的問題。
4.1 hibernate里面配置level字段后,則會報列名無效,
如果一定要用這個,則需要用‘’括起來,就解決問題。
?
錯誤的方式:
Xml代碼?
?
正確的方式:
Xml代碼?
??
4.2 Mybatis中插入數據時,多了個逗號
?
insert?into?yw_cb_grjbzl?(xm,xb,csny,mz,)?values?('張三','女','漢族',);
?
?
?
?
?
?
?
?
總結
以上是生活随笔為你收集整理的07 ORA系列:ORA-01747 或列说明无效 user.table.column, table.column的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 06 ORA系列:ORA-01741 非
- 下一篇: 08 ORA系列:ORA-01861 文