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

Oracle.DataAccess.Client.OracleException ORA-01747: user.table.column, table.column 或列说明无效

 

原因1:

查了一下是由于Oracle 数据库列名起的不好引起的,名字用到了数据库的关键字。

如果列很多,又不好确定是哪个列名使用了关键字,以下建议可供参考:

我用以下方法定位

 select *

from v$reserved_words
where keyword

in(

select COLUMN_NAME

from all_tab_columns

where table_name = '表名大写' and owner='用户名大写'

);

原因2:

书写的SQL的Set语句中,异常的字符混入到列名称的前后,列名称写错了。

将控制台打印的sql语句在plsql中执行发现:sql语句在xml中拼接错误 。

 

本人的错误是属于第一、二种类同时存在的。而且第二种错误找起来更让人茫然,后来在文章2的参考下,终于找到了。

update HP_STATUS set BSM_ASSOCIATE = :BSM_ASSOCIATE, STATUS = :STATUS,OPERATE_USER_ID = :OPERATE_USER_ID, FTP_FOLDER_LOCATION = :FTP_FOLDER_LOCATION, DATA_STATUS = :DATA_STATUS, UDT = :UDT, DETAILS = :DETAILS, where FID = :FID

 

 

 

参考文章

1. 关于报错"ORA-01747: user.table.column, table.column 或列说明无效"的解决办法

2. peonyzzdx, ORA-01747: user.table.column, table.column 或列说明无效

 

posted @ 2017-01-06 09:49  wenglabs  阅读(3317)  评论(0编辑  收藏  举报