Oracle.DataAccess.Client.OracleException ORA-01747: user.table.column, table.column 或列说明无效
原因1:
查了一下是由于Oracle 数据库列名起的不好引起的,名字用到了数据库的关键字。
如果列很多,又不好确定是哪个列名使用了关键字,以下建议可供参考:
我用以下方法定位
select *
from v$reserved_words
where keywordin(
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.
2. peonyzzdx,