中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > 数据库综合
Firebird的Case表达式功能
作者:未知 时间:2004-12-21 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无

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

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

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