免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: lqzwch
打印 上一主题 下一主题

高难度SQL语句,高手请进! [复制链接]

论坛徽章:
0
11 [报告]
发表于 2003-06-25 14:31 |只看该作者

高难度SQL语句,高手请进!

多谢各位!这个问题已经困扰我好久了,早知道各位这么热心我早提问就好啦!唉,我真是不学无术啊。

论坛徽章:
0
12 [报告]
发表于 2003-06-26 11:52 |只看该作者

高难度SQL语句,高手请进!

前提是计算值不可能为负数,但有可能遇到分子分母同时为0的情况,我改写的代码如下:
insert into B(B1,B2,B3) select T1/decode(T2,0,-1*(T1+1),T2), T1/decode(T3,0,-1*(T1+1),T3),T1/decode(T4,0,-1*(T1+1),T4) from A;
update B set B1=-1 where B1<0;
update B set B2=-1 where B1<0;
update B set B3=-1 where B1<0;

论坛徽章:
0
13 [报告]
发表于 2003-06-26 12:49 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
14 [报告]
发表于 2003-06-26 16:54 |只看该作者

高难度SQL语句,高手请进!

Who can explain the usage of funcation---decode?
Thanks in advanced!

论坛徽章:
0
15 [报告]
发表于 2003-06-26 17:29 |只看该作者

高难度SQL语句,高手请进!

b = decode(a,v1,t1,v2,t2,...,t0)
explain in C

  1. switch (a) {
  2.   case v1: b = t1; break;
  3.   case v2: b = t2; break;
  4.   ....
  5.   default: b = t0;
  6. }
复制代码


explain in Basic

  1. select case a
  2.   case 1:
  3.      b = t1
  4.   case 2:
  5.      b = t2
  6.   ....
  7.   else
  8.      b = t0
  9. end select
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP