欢迎光临
我们一直在努力

Firebird的Case表达式功能-数据库专栏,SQL Server

建站超值云服务器,限时71元/月

    说来惭愧,自从fb1.5出来以后,一直没有顾上很深入的挖掘它的新功能,只是当它是ib的一个延续来对待——只要能平滑移植,就算ok。

说来惭愧,自从fb1.5出来以后,一直没有顾上很深入的挖掘它的新功能,只是当它是ib的一个延续来对待——只要能平滑移植,就算ok。
    前两天才发现,firebird 1.5.2里,已经支持了case 表达式。在我看来,这是关系型数据库中一个相当重要的功能,因为利用case,可以生成强大的数据透视表——这个东西好像在excel等电子表格里有个专门的名字,忘了是啥了。但它绝对是一种非常有用的功能。当然,我们可以用电子表格软件实现这个功能,但是会带来额外的网络通讯负担,其计算效率也差很多。
以下是利用fb的demo数据库employee编写的一个透视表示例:

select cust_no
      ,sum(case when order_status = shipped then 1 else 0 end) as shipped
      ,sum(case when order_status = open then 1 else 0 end) as open
      ,sum(case when order_status = waiting then 1 else 0 end) as waiting
from sales
group by cust_no

它生成的结果集以每个客户的订单按处理状态分类统计。

,因为利用case,可以生成强大的数据透视表——这个东西好像在excel等电子表格里有个专门的名字,忘了是啥了。但它绝对是一种非常有用的功能。当然,我们可以用电子表格软件实现这个功能,但是会带来额外的网络通讯负担,其计算效率也差很多。
以下是利用fb的demo数据库employee编写的一个透视表示例:

select cust_no
      ,sum(case when order_status = shipped then 1 else 0 end) as shipped
      ,sum(case when order_status = open then 1 else 0 end) as open
      ,sum(case when order_status = waiting then 1 else 0 end) as waiting
from sales
group by cust_no

它生成的结果集以每个客户的订单按处理状态分类统计。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » Firebird的Case表达式功能-数据库专栏,SQL Server
分享到: 更多 (0)

相关推荐

  • 暂无文章