2017-01-19 23 views
0

我有一个在sql管理工作室工作的查询,但是当我运行这个SSRS/Visual Studio时,出现错误“无法读取数据集dataset1的下一个数据行。错误的数据类型为nvarchar转换为数字”无法读取数据集的下一个数据行

select 

    concat(
    right(replace(oe_hdr.po_no, '-', ''),8), 
    right(concat('000',job_price_line.line_no),3), 
    format(oe_pick_ticket_detail.unit_quantity, '00000000'), 
    cast(job_price_line.customer_part_no as char(20)), 
    oe_pick_ticket.invoice_no) as [po/line/release/qty/cust part no as 20 characters/invoice] 




    from oe_pick_ticket 

join oe_pick_ticket_detail on oe_pick_ticket_detail.pick_ticket_no = oe_pick_ticket.pick_ticket_no 
join oe_hdr on oe_hdr.order_no = oe_pick_ticket.order_no 
join job_price_hdr on oe_hdr.job_price_hdr_uid = job_price_hdr.job_price_hdr_uid 
join job_price_line on job_price_line.inv_mast_uid = oe_pick_ticket_detail.inv_mast_uid and job_price_line.job_price_hdr_uid = oe_hdr.job_price_hdr_uid 
join ship_to on ship_to.ship_to_id = oe_hdr.address_id 
join branch on branch.branch_id = ship_to.default_branch 
join customer on customer.customer_id = oe_hdr.customer_id 

where oe_pick_ticket.invoice_no in ('1218972', '1218983') 
and job_price_line.row_status_flag != '705' 
and oe_pick_ticket_detail.ship_quantity > '0' 

enter image description here

但是当我运行本作SSRS - 我增加更多的参数,我的where子句是这样的:

where oe_pick_ticket.invoice_no in (@invoiceno1, @invoiceno2, @invoiceno3, 
    @invoiceno4, @invoiceno5, @invoiceno6, @invoiceno7 ,@invoiceno8, 
@invoiceno9, @invoiceno10, @invoiceno11, @invoiceno12, @invoiceno13, 
@invoiceno14, @invoiceno15, @invoiceno16, @invoiceno17, @invoiceno18, 
@invoiceno19, @invoiceno20) 
     and job_price_line.row_status_flag != '705' 
     and oe_pick_ticket_detail.ship_quantity > '0' 

它返回错误

enter image description here

+0

检查表中的'invoice_no','row_status_flag'和'ship_quantity'类型,并确保您使用的是SAME类型的参数,并且正确填写这些参数。 –

+0

“oe_pick_ticket.invoice_no”的数据类型是什么? –

+0

看来你的数据集正在返回一个nvarchar值,但是在处理数据时,它正试图对它执行算术运算,这会导致错误。尝试在使用该列的表达式中使用CDBL(Fields!YourField.Value)。 –

回答

0

我发现我不得不让我所有的参数的空表达式。这解决了我的问题。