Firebird的Case表达式功能

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

说来惭愧,自从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

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航