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 或列说明无效
没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。