连接语句中出现错误“ORA-00932:不一致的数据类型:预期 - 得到了BLOB”

时间:2012-02-20 08:16:53

标签: sql database oracle join ora-00932

我在下面的存储过程中执行时遇到问题 我添加时收到ORA-00932: inconsistent datatypes: expected - got BLOB错误 下面存储过程中的FM.FAXFILE_BLOB列。FAXFILE_BLOB是一个blob字段。

如果我删除此字段,一切正常。我不知道为什么会发生这种情况。
请帮忙....

        CREATE OR REPLACE Procedure HCADMIN.Proc_GetFaxDetailsByDate
         ( 
           FromDate varchar2 default null,
           ToDate varchar2 default null,
           FaxNo varchar2 default null,
           ClaimNo varchar2 default null,
            NspCode varchar2 default null,
           PolicyNo varchar2 default null,
           HEGICNo varchar2 default null,
           cur_faxdetails OUT SYS_REFCURSOR
           )
        IS
       BEGIN
      OPEN cur_faxdetails For

      Select distinct
       FM.RECORDNO_NUM,
       FM.CLAIMNO_VAR,
       FM.FAXNO_VAR,
       FM.FAXSTATUS_VAR,
       FM.FAXTYPE_VAR,
       FM.USERNAME_VAR,
       FM.HEGIC_NO_VAR, 
       FM.RESEND_NO_NUM,
       FM.RESNDCOUNT_NUM,
       TO_date(FM.TIMESTAMP_DTE,'dd/MM/yyyy') as "TIMESTAMP_DTE",
       FR.RECIPIENTFAXNO_VAR,
       FM.FAXFILE_BLOB

       From TPA_FAXMASTER FM Left  join TPA_FAXRECIPIENT FR on                                      FM.RECORDNO_NUM=FR.RECORDNO_NUM 
 WHERE 
      NVL(FM.FAXNO_VAR,'0')=NVL(FaxNo,NVL(FM.FAXNO_VAR,'0')) And
      NVL(FR.RECIPIENTFAXNO_VAR,'0')=NVL(FaxNo,NVL(FR.RECIPIENTFAXNO_VAR,'0')) And          
      NVL(FM.CLAIMNO_VAR,'0')=NVL(ClaimNo,NVL(FM.CLAIMNO_VAR,'0')) And  
      NVL(FM.NSPID_VAR,'0')=NVL(NspCode,NVL(FM.NSPID_VAR,'0')) And
      NVL(FM.POLICYNO_VAR,'0')=NVL(PolicyNo,NVL(FM.POLICYNO_VAR,'0')) And  
      NVL(FM.HEGIC_NO_VAR,'0')=NVL(HEGICNo,NVL(FM.HEGIC_NO_VAR,'0')) And    
      (NVL(TO_date(FM.TIMESTAMP_DTE,'dd/MM/yyy'),To_Date('09/09/9999','dd/MM/yyyy')) 
      BETWEEN NVL (TO_date(FromDate,'dd/MM/yyyy'), NVL(TO_date(FM.TIMESTAMP_DTE,'dd/MM/yyy'),To_Date('09/09/9999','dd/MM/yyyy')))
      AND  NVL (TO_date(ToDate,'dd/MM/yyyy'), NVL(TO_date(FM.TIMESTAMP_DTE,'dd/MM/yyy'),To_Date('09/09/9999','dd/MM/yyyy'))));
EXCEPTION
 WHEN NO_DATA_FOUND THEN
   Null;
 WHEN OTHERS THEN
   -- Consider logging the error and then re-raise
   RAISE;
 END;
 /

2 个答案:

答案 0 :(得分:13)

如果select_list包含LOB列,则无法指定DISTINCT

尝试使用标量子查询来获取BLOB字段。

答案 1 :(得分:2)

以下限制适用于集合运算符。

  

集合运算符受以下限制:

     

set运算符在BLOB,CLOB,BFILE类型的列上无效,   VARRAY或嵌套表。

     

UNION,INTERSECT和MINUS运算符在LONG上无效   列。

     

如果set运算符前面的选择列表包含表达式,   那么你必须为表达式提供一个列别名   在order_by_clause中引用它。

     

您也不能使用set运算符指定for_update_clause。

     

您无法在这些子查询中指定order_by_clause   运算符。

     

您不能在包含TABLE的SELECT语句中使用这些运算符   集合表达。

参考doc