通过function解决部分复杂查询的方法

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

在做一个论坛时,需要取出论坛中某个板块的相关信息,同时要取得该板块的版主信息(姓名及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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航