My FAQ,最新最全的IT技术FAQ
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 未整理篇 | 技术讨论
  当前位置: > 操作系统 > IBM Server
急问 sql中 join的问题!!!!
作者:未知 时间:2005-09-13 15:45 出处:ChinaUnix.net 责编:My FAQ
              摘要:急问 sql中 join的问题!!!!

在作 left out join 时, 主表在和附表进行联接是,附表中如果有不匹配的记录,相应的值会为null值。 有没有办法,让相应的值为0(数字域)或是其他缺性值。 现在要把主表和附表的值相加,如果附表的值为null, 则希望结果是主表的值加上0,得出结果

万分感谢!!!

 WJIEGAO 回复于:2004-07-14 15:54:55
用函数NVL,
SELECT NVL(CODE,0)~~~
这样不就可以实现你想要的吗

 wildfish 回复于:2004-07-14 21:01:10
如果是字符串,是不是就用SELECT NVL(CODE,' ')~~~~

 WJIEGAO 回复于:2004-07-15 11:02:20
[quote:4fb46ed49a="wildfish"]如果是字符串,是不是就用SELECT NVL(CODE,' ')~~~~[/quote:4fb46ed49a]

YES~~~

 wildfish 回复于:2004-07-20 11:51:01
SELECT NVL(B.EQCVSL,'A')
FROM ECDFILELIB/EQEEIRPF A 
LEFT  JOIN ECDFILELIB/EQLVOYPF B 
ON A.EQCVSL=B.EQCVSL 
AND A.EQVOY=B.EQVVOY 
WHERE A.EQEEIR>='E200401010000'                    
我这样写没错吧,可是strsql说找不到这个方法
是不是你这个nvl是自定义的函数?

 wildfish 回复于:2004-07-20 17:14:46
正解
SELECT IFNULL(B.EQCVSL,'A') 
FROM ECDFILELIB/EQEEIRPF A 
LEFT JOIN ECDFILELIB/EQLVOYPF B 
ON A.EQCVSL=B.EQCVSL 
AND A.EQVOY=B.EQVVOY 
WHERE A.EQEEIR>='E200401010000'

 WJIEGAO 回复于:2004-07-20 17:16:32
这个函数是ORACLE的,DB2应该没有这个函数,忘了说明了.哈哈SORRY~~

 dragon111 回复于:2004-07-21 08:40:15
db2 中是 COALESCE

 WJIEGAO 回复于:2004-07-21 09:39:06
[quote:f47435c774="dragon111"]db2 中是 COALESCE[/quote:f47435c774]

Thanks ~~~~~

 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 myfaq.com.cn All rights reserved. www.myfaq.com.cn 版权所有