首页 > 编程 > .NET > 正文

ASP.NET无限分类

2024-07-10 13:11:28
字体:
来源:转载
供稿:网友

开始在网上查找到asp的无限分类,但是asp.net的几乎找不到,找到的也是跟treeview结合起来的.
找到asp版本的代码有几种,原来都差不多是采用递归算法.
其中表结构都是如下:
表名称是classname
id                     主键
sid                    对应的父类的id
classname        对应类别的名称.
代码段一:
1function loadnexttype(upid,rank)
2    dim rs
3    set rs="select * from classname where sid="&upid
4    do while not rs.eof
5       loadnexttype=loadnexttype &rs("classname")&"<br>"& string("-",rank) & loadnexttype(rs("id"),rank+1)
6       rs.movenext
7    loop
8end function调用时:response.write(loadnexttype(0,0))

另外一段代码就跟上面原理就一样的.只不过是加入了树型结构的显示方式.
代码段二:
 1'定义第一级分类
 2sub mainfl()
 3       dim rs
 4       set rs=conn.execute("select id,f_id,f_name from classnae where sid=0 order by id desc")
 5       if not rs.eof then
 6          do while not rs.eof
 7          response.write rs(2) & "<br>"
 8          call subfl(rs(0),"  |-") '循环子级分类
 9          rs.movenext
10          if rs.eof then exit do '防上造成死循环
11          loop
12          end if
13end sub
14'定义子级分类
15sub subfl(fid,strdis)
16       dim rs1
17       set rs1=conn.execute("select id,sid,classname from classname where sid="&fid&" order by id desc")
18       if not rs1.eof then
19       do while not rs1.eof
20       response.write rs1(2) & "<br>"
21       call subfl(rs1(0),"  "&strdis) '递归子级分类
22       rs1.movenext
23       if rs1.eof then
24       rs1.close
25       exit sub
26       end if
27       loop
28       end if
29end sub
我参考上面的代码改成了asp.net版本的无限分类.开始遇到了语法上的限制.当时的处理是直接把rs换成sqldatareader,然后加以修改,代码如下(错误代码):
测试数据库的表tree结构是:id,parentid,name。
 1private void display(string parentid/**//*, int rank*/)
 2    {
 3        sqldatareader dr;
 4        sqlcommand cmd;
 5        string strsql;
 6
 7        strsql = "select * from tree where parentid =" + parentid + "order by id desc";
 8        cmd = new sqlcommand(strsql,conn);
 9        //cmd.connection.open();
10
11        using(dr = cmd.executereader())
12        {
13            while(dr.read())
14            {
15                response.write(dr["name"].tostring() + "<br>");
16                display(dr["id"].tostring());
17            }
18        }
19        cmd.connection.close();
20    }调用使用display("0").
错误原因是sqldatareader每次使用之后都需要关闭,所以datareader是不可以嵌套使用的.
后来我改成了用datatable的形式实现了无限分类,但是感觉这种方式的效率不高,需要改进(还在研究中)
修改后的代码如下:
 1private void display(string parentid, string space)
 2    {
 3        datatable dt;
 4        string strsql;
 5        strsql = "select * from tree where parentid =" + parentid + " order by id desc";
 6
 7        sqldataadapter sda = new sqldataadapter(strsql, conn);
 8        dataset ds = new dataset();
 9        sda.fill(ds, "tree");
10        dt = ds.tables["tree"];
11
12        if (dt.rows.count > 0)
13        {
14            foreach (datarow dr in dt.rows)
15            {
16                stropinion += space + "<font color=red>[" + dr["name"].tostring() +"<br>";
17                display(dr["id"].tostring(), "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" + space, false);
18            }
19        }
20    }调用时候使用display("0","↓→→")。
虽然是实现了无限分类,但是效率还是挺低,努力探索更高的效率。

出处:p.dragon's blog

国内最大的酷站演示中心!
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表