0

我在查询中收到以下错误:

在函数“DECFLOAT”的字符串参数中发现无效字符。

但是,我没有对我选择的任何字段进行任何更改:

select
RQH.COMPANY, 
RQH.LAST_APRV_DT, 
RQH.CREATION_DATE, 
RQH.RELEASED_DATE, 
RQH.REL_OPER_ID, 
RQH.REQ_NUMBER, 
RQH.REQUESTER, 

RLN.COMPANY, 
RLN.BUYER,
RLN.DESCRIPTION, 
RLN.TRAN_UNIT_COST, 
RLN.QUANTITY, 
RLN.ITEM, 
RLN.VEN_ITEM, 
RLN.LINE_NBR, 
RLN.MANUF_CODE, 
RLN.MANUF_NBR, 
RLN.VENDOR, 
RLN.REQ_NUMBER, 
RLN.ENTERED_UOM, 


MMD.LINE_NBR, 
MMD.DOC_NBR_NUM, 

VEN.VENDOR_VNAME, 
VEN.VENDOR_GROUP, 
VEN.VENDOR

from mmd 

join rln on MMD.COMPANY = rln.COMPANY and MMD.DOC_NBR_NUM = rln.REQ_NUMBER 
    and MMD.LINE_NBR = rln.LINE_NBR

join cpy on rln.company = cpy.company

join ven on VEN.VENDOR_GROUP = cpy.VENDOR_GROUP and VEN.VENDOR = rln.VENDOR

join rqh on RLN.COMPANY = RQH.COMPANY and RLN.REQ_NUMBER = RQH.REQ_NUMBER

where ven.vendor = 20200
4

2 回答 2

0

您的比较之一在一侧具有数字数据类型,在另一侧具有字符数据类型。该对中字符列中的一个值不能转换为数字。Db2数据类型转换规则规定,如果一个操作数是数字而另一个是字符类型,则字符值将被隐式强制转换为数字。对于无法强制执行的值,这显然会失败。如果这是一个有效值,您需要将数字列显式转换为字符数据类型(根据需要用空格填充)。

于 2017-12-15T21:52:31.977 回答
-1

如果您完全删除“WHERE”子句,您仍然会收到错误还是会消失?

于 2017-12-22T06:19:01.293 回答