爱心技术专栏专题

ction解决部分复杂查询的方法

摘录:sql server 来源:sql server 加入时间:2007年04月24日
摘要:
ction解决部分复杂查询的方法


在做一个论坛时,需要取出论坛中某个板块的相关信息,同时要取得该板块的版主信息(姓名及Id),但版主可能是多个,不便于使用直接关联的手段来实现,那样可能导致数据量大,而且会增加程序的复杂度。
后考虑一种变通的手段,可以利用一个function来取得所有版主信息,将他们拼合为一个字符串,在取得板块信息时,在select语句中加入一个function ,从而得到相应的结果。
以下是部…

ction解决部分复杂查询的方法

站点:爱心种子小博士 关键字:ction解决部分复杂查询的方法

ction解决部分复杂查询的方法

在做一个论坛时,需要取出论坛中某个板块的相关信息,同时要取得该板块的版主信息(姓名及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;
转载:转载请保留本信息,本文来自http://www.51dibs.com/lp07/la/a17/l_a_bb5c141f77e60bde.html