PostgreSQL学习手册(SQL语言函数)(2)

来源:未知 责任编辑:责任编辑 发表时间:2014-05-20 18:35 点击:
        salary      numeric,
        age         integer,
    );
    2). 创建函数,其参数为复合类型。在函数体内,可以像引用基本类型参数那样引用复合类型,如$1。访问复合类型的字段使用点表达式即可,如:$1.salary。
    CREATE FUNCTION double_salary(emp) RETURNS integer AS $$
        SELECT ($1.salary * 2)::integer AS salary;
    $$ LANGUAGE SQL;
    3). 在select语句中,可以使用emp.*表示emp表的一整行数据。
    SELECT name, double_salary(emp.*) AS dream FROM emp WHERE age > 30;
    4). 我们也可以使用ROW表达式构造自定义的复合类型,如:
    SELECT name, double_salary(ROW(name, salary*1.1, age)) AS dream FROM emp;
    5). 创建一个函数,其返回值为复合类型,如:
    CREATE FUNCTION new_emp() RETURNS emp AS $$
        SELECT ROW('None', 1000.0, 25)::emp;
    $$ LANGUAGE SQL;
    6). 调用返回复合类型的函数。
    SELECT new_emp();
    7). 调用返回复合类型的函数,同时访问该返回值的某个字段。
    SELECT (new_emp()).name;
 
四、带输出参数的函数:
 
    还有一种方法可以用于返回函数执行的结果,即输出参数,如:
    CREATE FUNCTION add_em2 (IN x int, IN y int, OUT sum int) AS $$
        SELECT $1 + $2  www.2cto.com  
    $$ LANGUAGE SQL;
    调用方法和返回结果与add_em(带有返回值的函数)完全一致,如:
    SELECT add_em(3,7);
    
    这个带有输出参数的函数和之前的add_em函数没有本质的区别。事实上,输出参数的真正价值在于它为函数提供了返回多个字段的途径。如,
    CREATE FUNCTION sum_n_product (x int, y int, OUT sum int, OUT product int) AS $$
        SELECT $1 + $2, $1 * $2
    $$ LANGUAGE SQL;
    调用方式没有改变,只是返回结果多出一列。
    SELECT * FROM sum_n_product(11,42);
     sum | product
    -----+---------
      53 |     462
    (1 row)
    在上面的示例中,IN用于表示该函数参数为输入参数(缺省值,可以忽略),OUT则表示该参数为输出参数。
 
五、返回结果作为表数据源:
 
    所有SQL函数都可以在查询的FROM子句里使用。该方法对于返回复合类型的函数而言特别有用,如果该函数定义为返回一个基本类型,那么该函数生成一个单字段表,如果该函数定义为返回一个复合类型,那么该函数生成一个复合类型里每个属性组成的行。见如下示例:
    1). 创建一个数据表。
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • Request.ServerVariables 参数大全
  • 执行全文索引时出现权限不足的解决方法
  • 导入excel文件处理流程节点的解决方案
  • 查看sql修改痕迹(SQL Change Tracking on Table)
  • MongoDB安装为Windows服务方法与注意事项
  • App数据层设计及云存储使用指南
  • PostgreSQL启动过程中的那些事三:加载GUC参数
  • 写给MongoDB开发者的50条建议Tip1
  • Percolator与分布式事务思考(二)
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1