数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
通过function解决部分复杂查询的方法

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

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




相关文章

相关软件