Oracle中报无效数字

如下语句:

select *
  from (select rownum r, t.*
          from (select s.c_id,
                       f.c_id fileid,
                       f.c_title title,
                       l.c_id lid,
                       l.c_strshortname,
                       l.C_STRCORPNAME,
                       l.c_strshortname || p.c_packname corppack,
                       p.c_id pid,
                       p.c_packname,
                       p.c_packcode,
                       nvl(a.c_qty, 0) c_qty,
                       o.c_stockorder,
                       c.c_bzname,
                       c.c_strprodname,
                       c.c_nocodeid,
                       c.C_MEASUNIT,
                       c.C_PRICEDW,
                       a.c_iftax,
                       a.c_price,
                       (select c_explain
                          from t_supplierenter
                         where c_project = p.c_project
                           and c_supplierid = s.c_supplier) explain,
                       decode(s.c_resultstatus, '1', '已签收', '未签收') c_rs
                  from t_bidpacksupp s
                  left join t_bidpackorder o
                    on o.c_bidpack = s.c_bidpack
                  left join t_stockaffirmpart a
                    on s.c_supplier = a.c_supplier
                   and a.c_bidpack = s.c_bidpack
                   and a.c_stockorder = o.c_stockorder
                  left join t_bidpack p
                    on s.c_bidpack = p.c_id
                  left join t_stockorder c
                    on c.c_id = o.c_stockorder
                  left join t_supplier l
                    on l.c_id = s.c_supplier
                  left join t_bidattachment f
                    on f.c_project = p.c_project
                   and f.c_supplier = s.c_supplier
                   and f.c_type = 14
                 where p.c_project = 7741848774
                   and p.c_process <> 7741075449
                 order by l.c_id, p.c_id, o.c_stockorder) t
         where rownum <= 50)
 where r > 0

报无效数字,可能是字段匹配时类型不一样,修改如下即可:

select *
  from (select rownum r, t.*
          from (select s.c_id,
                       f.c_id fileid,
                       f.c_title title,
                       l.c_id lid,
                       l.c_strshortname,
                       l.C_STRCORPNAME,
                       l.c_strshortname || p.c_packname corppack,
                       p.c_id pid,
                       p.c_packname,
                       p.c_packcode,
                       nvl(a.c_qty, 0) c_qty,
                       o.c_stockorder,
                       c.c_bzname,
                       c.c_strprodname,
                       c.c_nocodeid,
                       c.C_MEASUNIT,
                       c.C_PRICEDW,
                       a.c_iftax,
                       a.c_price,
                       (select c_explain
                          from t_supplierenter
                         where c_project = p.c_project
                           and c_supplierid = s.c_supplier) explain,
                       decode(s.c_resultstatus, '1', '已签收', '未签收') c_rs
                  from t_bidpacksupp s
                  left join t_bidpackorder o
                    on o.c_bidpack = s.c_bidpack
                  left join t_stockaffirmpart a
                    on s.c_supplier = a.c_supplier
                   and a.c_bidpack = s.c_bidpack
                   and a.c_stockorder = o.c_stockorder
                  left join t_bidpack p
                    on s.c_bidpack = p.c_id
                  left join t_stockorder c
                    on c.c_id = o.c_stockorder
                  left join t_supplier l
                    on l.c_id = s.c_supplier
                  left join t_bidattachment f
                    on f.c_project = to_char(p.c_project)  --修改此处
                   and f.c_supplier = to_char(s.c_supplier)  --修改此处
                   and f.c_type = 14
                 where p.c_project = 7741848774
                   and p.c_process <> 7741075449
                 order by l.c_id, p.c_id, o.c_stockorder) t
         where rownum <= 50)
 where r > 0


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值