且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

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

更新时间:2022-09-02 18:30:06

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

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中拼接错误 。
ORA-01747: user.table.column, table.column 或列说明无效

 

本人的错误是属于第一、二种类同时存在的。而且第二种错误找起来更让人茫然,后来在文章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 或列说明无效

 

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





    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/6255101.html,如需转载请自行联系原作者