SQL入门:使用函数

发表于:2007-06-21来源:作者:点击数: 标签:
本节简要介绍了将用于全书示例的函数。 数据库 函数是一组输入数据值和一个结果值之间的关系。 函数可以是内部的或用户定义的。 DB2 通用数据库提供很多内部函数和预安装的用户定义函数。可找到 SYSIBM 模式的内部函数和 SYSFUN 模式的预安装的用户定义函数

   
  本节简要介绍了将用于全书示例的函数。 数据库函数是一组输入数据值和一个结果值之间的关系。
  

  函数可以是内部的或用户定义的。 DB2 通用数据库提供很多内部函数和预安装的用户定义函数。可找到 SYSIBM 模式的内部函数和 SYSFUN 模式的预安装的用户定义函数。SYSIBM 和 SYSFUN 是保留模式。
  
  内部函数和预安装的用户定义函数从不会满足所有需求。所以应用程序开发者可能需要创建自己的一套特定于他们的应用程序的函数。用户定义函数使这成为可能,例如通过扩展 DB2 通用数据库的范围以包括定制的商业或科学函数。这在 用户定义函数中(点击查看) 进一步讨论。
  
  
  列函数
  列函数对列中的一组值进行运算以得到单个结果值。下列就是一些列函数的示例。有关完整列表,参考 SQL Reference。
  
  
  
  AVG
  返回某一组中的值除以该组中值的个数的和
  
  COUNT
  返回一组行或值中行或值的个数
  
  MAX
  返回一组值中的最大值
  
  MIN
  返回一组值中的最小值
  下列语句从 STAFF 表中选择最高薪水:
  
   SELECT MAX(SALARY)
    FROM STAFF
  
  此语句从员工 STAFF 样本表中返回值 22959.20。
  
  下一个示例选择其收入超过平均收入但在公司的年数少于平均年数的雇员姓名和薪水。
  
   SELECT NAME, SALARY
    FROM STAFF
    WHERE SALARY > (SELECT AVG(SALARY) FROM STAFF)
    AND YEARS < (SELECT AVG(YEARS) FROM STAFF)
  
  此语句产生下列结果:
  
   SQL入门:使用函数(图一)
  
  在上面示例中的 WHERE 子句中,与直接实现列函数 (WHERE SALARY > AVG(SALARY)) 相反,在子查询中说明列函数。不能在 WHERE 子句中说明列函数。这是由于运算次序的结果。可认为 WHERE 子句是在 SELECT 子句之前进行计算的。因此,当正在计算 WHERE 子句时,列函数没有对该组值的存取权。稍后由 SELECT 子句选择这组值。
  
  可指定 DISTINCT 作为列函数自变量的一部分,以在应用函数之前消除重复值。因此,COUNT(DISTINCT WORKDEPT) 计算不同部门的个数。
  
  
  标量函数
  标量函数对值进行某个运算以返回另一个值。下列就是一些由DB2 通用数据库提供的标量函数的示例。
  
  
  ABS
  返回数的绝对值
  
  HEX
  返回值的十六进制表示
  
  LENGTH
  返回自变量中的字节数(对于图形字符串则返回双字节字符数。)
  
  YEAR
  抽取日期时间值的年份部分
  有关标量函数的详细列表和说明,参考 SQL Reference。
  
  下列语句返回 ORG 表中的部门名称以及其每个名称的长度:
  
   SELECT DEPTNAME, LENGTH(DEPTNAME)
    FROM ORG
  
  此语句产生下列结果:
  
  SQL入门:使用函数(图二)
  
  注意:由于未使用 AS 子句给 LENGTH(DEPTNAME) 取一个有意义的名称,所以第二列中出现系统生成的数字。

原文转自:http://www.ltesting.net