用排序串字段实现树状结构(存储过程)

存储过程|排序

加贴存储过程:
if exists (select * from sysobjects where id = object_id("lybsave"))
   drop proc lybsave
CREATE PROCEDURE [lybsave] @keyid int=0,@guestname varchar(20),@guestitle varchar(100),@guestcomm text,@guestemail varchar(50)='',@emailflag bit=0,@fromip varchar(15),@recimail varchar(50) OUTPUT
AS
DECLARE @ostr varchar(30),@rootid int,@lybid int,@ostrs varchar(30),@l tinyint,@tdt datetime,@putdate varchar(10),@puttime varchar(5),@eflag bit
select @tdt=getdate()
select @putdate=convert(varchar(4),datepart(yy,@tdt))+'-'+left('0'+convert(varchar(2),datepart(mm,@tdt)),2)+'-'+left('0'+convert(varchar(2),datepart(dd,@tdt)),2)
select @puttime=left('0'+convert(varchar(2),datepart(hh,@tdt)),2)+':'+left('0'+convert(varchar(2),datepart(mi,@tdt)),2)
select @ostr='',@rootid=0,@lybid=0,@l=0
if (@guestemail='') select @emailflag=0
If @keyid=0  --发新贴
  goto newin
ELSE
begin
  SELECT @lybid=lybid,@rootid=rootid,@ostr=orderstr,@recimail=guestemail,@eflag=emailflag from guestbook where lybid=@keyid
  IF @lybid=0  --回复贴没找到,当新贴发表
   goto newin
  ELSE
   BEGIN
    if (@eflag=0 and @guestemail<>'swuse@21cn.com abc') select @recimail=''  --如果是版主回复且指定发邮件给提问者,则不管发贴者是否要求回复,后面的abc相当于管理密码
    if (@rootid=0) select @rootid=@lybid
    select @ostrs=@ostr+'%',@lybid=0
    select top 1 @lybid=lybid,@ostrs=orderstr from guestbook where rootid=@rootid and (orderstr like @ostrs) and lybid<>@keyid order by orderstr
    if (@lybid=0) select @ostr=@ostr+char(122)
    else
     begin
      select @l=len(@ostrs)
      select @ostr=left(@ostrs,@l-1)+char(ascii(substring(@ostrs,@l,1))-1)
     end
    goto newin
   end
end

newin:
    INSERT into guestbook (guestname,guestitle,guestcomm,putdate,puttime,guestemail,emailflag,rootid,fromip,orderstr) values(@guestname,@guestitle,@guestcomm,@putdate,@puttime,rtrim(@guestemail),@emailflag,@rootid,@fromip,@ostr)

删贴(剪枝)存储过程:

if exists (select * from sysobjects where id = object_id("lybdel"))
   drop proc lybdel
CREATE PROCEDURE [lybdel] @keyid int
AS
DECLARE @ostr varchar(30),@rootid int,@lybid int
select @ostr='',@rootid=0,@lybid=0
SELECT @ostr=orderstr,@rootid=rootid,@lybid=lybid from guestbook where lybid=@keyid
if (@lybid<>0)
  BEGIN
    if (@rootid=0) select @rootid=@lybid
    SELECT @ostr=@ostr+'%'
    DELETE FROM guestbook where orderstr like @ostr and rootid=@rootid or lybid=@rootid
  END

软件使用主页http://swuse.yeah.net创作

时间: 2024-08-06 04:09:38

用排序串字段实现树状结构(存储过程)的相关文章

用排序串字段实现树状结构(原理)

排序     实现原理:以一排序字段(字符型实现排序),该字段的实际长度即为回复深度(用一位字符代表一层深度时).    所受限制:回复深度只受排序串定义长度的限制(有点象空间换深度),每贴回复数(包括根贴和子贴)为30左右(当sql server使用Dictionary order,case-insensitive排序方式,即不区分字母大小写时),如果sql server使用Binary orders排序方式时受限为127(255?).    改进方法:如果觉得不够用,可以使用多位字符对应一个

用排序串字段实现树状结构(库结构)

排序 以下是建立库结构的Sql语句(以一个简单的树状留言薄为例): if exists(select * from sysobjects where ID = object_id("guestbook"))  drop table guestbookgodrop table guestbookcreate table guestbook(  lybid int identity(1,1),  guestname varchar(40) NOT NULL,  guestitle varc

用排序串字段实现树状结构(例程——显示树)

排序|显示 程序index.asp功能:显示目录树 <!-- #include file="lybcon.inc" --><%pageno=request("pageno")searchtype=request("searchtype")searchnr=rtrim(request("searchnr"))set guestconn=Server.CreateObject("ADODB.connec

用排序串字段实现树状结构(例程——连接字串)

排序 程序名称:lybcon.inc程序功能:数据库连接字符串 <%lybstr="Provider=SQLOLEDB.1;Password=密码;Persist Security Info=True;User ID=sa;Initial Catalog=数据库名;Data Source=数据库服务器名;Connect Timeout=15" %>注意:一时疏忽,请使用.asp作为连接字符串文件名--有些服务器没有为.inc文件指定对应的映射,从而可以看到.inc的文件内容

用排序串字段实现树状结构(例程——回复表单)

排序 程序名称:revert.asp程序功能:回复表单 <!-- #include file="lybcon.inc" --><%pageno=request("pageno")keyid=request("keyid")posttype=request("type")if posttype="revert" then  set guestconn=Server.CreateObject(

用排序串字段实现树状结构(例程——删除贴子)

排序 程序名称:delrec.asp程序功能:删除贴子(剪枝) <!-- #include file="lybcon.inc" --><%flag=request("flag")keyid=request("keyid")pageno=request("pageno")password=request.form("password")if flag="1" then  

用排序串字段实现树状结构(例程——保存贴子内容)

排序 程序名称:savelyb.asp程序功能:保存贴子内容 <!-- #include file="lybcon.inc" --><%posttype=request("posttype")pageno=request("pageno")keyid=request("keyid")if keyid="" then keyid=0emailpost=request("emailp

用排序串字段实现树状结构(例程——显示贴子内容)

排序|显示 程序:disprec.asp功能:显示贴子具体内容 <!-- #include file="lybcon.inc" --><%keyid=request("keyid")rootid=request("rootid")pageno=request("pageno")if rootid=0 then rootid=keyidset guestconn=Server.CreateObject(&quo

使用“使用中值排序基数法”实现树状结构(一)

排序|排序 在BBS的编写中,经常有人问怎样实现树状结构?一个比较不负责任的回答是:使用递归算法.当然,递归是一个可行的办法(二叉树的历遍也好象只能使用递归算法),但对于BBS来说,这样做势必要进行大量的Sql查询(虽然可以使用存储过程来做,但要从根本上加快速度,则应该考虑更快的算法). 下面给出一个可行的彻底屏弃递的实现树状结构的算法. 下面给出另一种使用"使用中值排序基数法"实现树状结构: 一.主要思想:增加一个排序基数字段ordernum,回复同一根贴的贴子中插入贴子时,排序