免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4298 | 回复: 3
打印 上一主题 下一主题

Function 格式请教哪里的错误。。请帮忙看看 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-05-01 17:49 |只看该作者 |倒序浏览

  1. create or replace function
  2.         Q4(integer,text) returns setof RoomUsageTuple
  3. as
  4. '   select room.name,count as nclasses
  5.             From (select room,count(room)
  6.                   from ((select id
  7.                          from course
  8.                          where (select term.id
  9.                                 from   term
  10.                                 where  term.year = $1
  11.                                        and term.sess = $2) = course.term)s join class on s.id = class.course)s1
  12.                                 group by room) s2,room
  13.             Where count = (select max(count)
  14.                            from (select room, count(room)
  15.                                  from ((select id
  16.                                         from course
  17.                                  where (select term.id
  18.                                         from   term
  19.                                         where  term.year = $1
  20.                                                and term.sess = $2) = course.term)s join class on s.id = class.course)s3
  21.                                                group by room)s4)
  22.                            and room = room.id;

  23. ' language plpgsql;
复制代码


请问哪里写错了呢?。。。谢谢。。。。中间那段QUERY是对的。。我已经测试过了。
是不是我放进去FUNCTION的时候写错啦?

总是会出现

  1. psql:ass2.sql:82: ERROR:  syntax error at or near "select"
  2. LINE 4:  select room, count(room)
复制代码

[ 本帖最后由 beyondever 于 2007-5-2 12:45 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-05-04 11:51 |只看该作者
如果是返回的是SETOF
必须一行行的返回 return next  



  1. declare
  2.      myrec record;
  3. begin
  4.     for myrec in select ..... loop
  5.         return next myrec
  6.    end loop;
  7.    return;
  8. end;
复制代码

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
3 [报告]
发表于 2007-05-04 15:04 |只看该作者
原帖由 beyondever 于 2007-5-1 17:49 发表
[code]
create or replace function
        Q4(integer,text) returns setof RoomUsageTuple
as
'   select room.name,count as nclasses
            From (select room,count(room)
                  from ((s ...

提示不是说参数有错误吗

提示是第四行  看第三行

那个 count 是聚合函数吧 括号呢

论坛徽章:
0
4 [报告]
发表于 2007-05-04 22:49 |只看该作者
count是我select的阿。。。。应为我的ROW叫 “count”阿。。。。。

我试一下。。谢谢。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP