加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 电商 > 正文

通过function办理部门伟大查询的要领

发布时间:2018-08-15 13:12:51 所属栏目:电商 来源:站长网
导读:在做一个论坛时,必要取出论坛中某个板块的相干信息,同时要取得该板块的版主信息(姓名及Id),但版主也许是多个,未便于行使直接关联的本领来实现,那样也许导致数据量大,并且会增进措施的伟大度。 后思量一种变通的本领,可以操作一个function来取得所

在做一个论坛时,必要取出论坛中某个板块的相干信息,同时要取得该板块的版主信息(姓名及Id),但版主也许是多个,未便于行使直接关联的本领来实现,那样也许导致数据量大,并且会增进措施的伟大度。
后思量一种变通的本领,可以操作一个function来取得全部版主信息,将他们拼合为一个字符串,在取得板块信息时,在select语句中插手一个function ,从而获得响应的功效。
以下是部门的例子:

----------操作function 取得版主信息
  FUNCTION getOwnerOfTheme(p_themeId NUMBER) RETURN VARCHAR2
  IS
     tempStr VARCHAR2(300);
     tempcur tcur;
     vuserid VARCHAR2(20);
     vusername VARCHAR2(20);
  BEGIN
       OPEN tempcur FOR SELECT a.userid,a.username
           FROM home_user a,home_forumowner b
           WHERE a.userid=b.userid AND b.themeid=p_themeId;
       LOOP
           FETCH tempcur INTO vuserid,vusername;
           EXIT WHEN tempcur%NOTFOUND OR tempcur%NOTFOUND IS NULL;
           tempStr:=tempStr || vuserid ||':'||vusername||',';
       END LOOP;
       CLOSE tempcur;
       RETURN tempStr;
  END;

---在挪用的存储进程中,在select子句中挪用function的值
 procedure()
is
begin
          SELECT themeId,getOwnerOfTheme(themeid) owner
           FROM home_forumtheme ORDER BY themeid;
end;

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读