通过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; (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |