日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

07 ORA系列:ORA-01747 或列说明无效 user.table.column, table.column

發布時間:2025/3/20 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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代碼?

  • <property?name="level"?type="java.lang.Integer">?
  • ?????????????<column?name="level"?precision="1"?scale="0"?/>?
  • ???????</property>?
  • ???</class>?
  • ?

    正確的方式:

    Xml代碼?

  • <property?name="level"?type="java.lang.Integer">?
  • ?????????????<column?name='"level"'?precision="1"?scale="0"?/>?
  • </property>????
  • ??

    4.2 Mybatis中插入數據時,多了個逗號

    ?

    insert?into?yw_cb_grjbzl?(xm,xb,csny,mz,)?values?('張三','女','漢族',);

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    總結

    以上是生活随笔為你收集整理的07 ORA系列:ORA-01747 或列说明无效 user.table.column, table.column的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。