通过function解决部分复杂查询的方法
发布时间:2018-08-16 22:55:12 所属栏目:电子商务 来源:站长网
导读:在做一个论坛时,需要取出论坛中某个板块的相关信息,同时要取得该板块的版主信息(姓名及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; (编辑:武汉站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读