仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 508|回复: 10
打印 上一主题 下一主题

[学习教程] ASP教程之bbs树形布局的完成办法(一)

[复制链接]
分手快乐 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 23:17:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
Access是一种桌面数据库,只适合数据量少的应用,在处理少量数据和单机访问的数据库时是很好的,效率也很高。但是它的同时访问客户端不能多于4个。access数据库有一定的极限,如果数据达到100M左右,很容易造成服务器iis假死,或者消耗掉服务器的内存导致服务器崩溃。bbs的树形布局显现能够有良多种办法,个中对照简单想到的是递回和排序串办法,但这两种办法并非很好,那末如何才算是对照公道的算法呢?
递回办法不必讲,人人都晓得怎样用,先讲讲排序串办法,最复杂的排序串办法能够如许用,只用一个id就能够完成树型,向如许
1001
2002
3001001
4001001001
5001002001
用这个字符串排序后就酿成如许:
001
001001
001001001
001002001
002
这类办法简单完成,但弱点也是很分明,一个是回帖数受限定,另外一个跟着回帖增添会愈来愈长,影响数据库效力。

上面一种办法是李龙的,属于变通的排序串办法
DDL
--------------
CREATETABLEdbo.Message
(
IDnumeric(18,0)IDENTITY(1000,1),
DateAndTimedatetimeDEFAULTgetdate()NOTNULL,
AuthorIDnumeric(18,0)NOTNULL,
Subjectnvarchar(250)NOTNULL,
BodyntextNULL,
LinkURLnvarchar(100)NULL,
TextForLinknvarchar(50)NULL,
ImageURLnvarchar(100)NULL,
ClassintDEFAULT0NOTNULL,
ClientInfonvarchar(250)NULL,
RemoteAddrnvarchar(50)NULL,
CONSTRAINTPK_BBSMessage
PRIMARYKEYNONCLUSTERED(ID,AuthorID)
)
go
CREATETABLEdbo.MsgRefTab
(
MsgIDnumeric(18,0)NOTNULL,
ParentIDnumeric(18,0)NOTNULL,
AncestorIDnumeric(18,0)NOTNULL,
ChildNumnumeric(18,0)DEFAULT0NOTNULL,
LinkStrnvarchar(250)NOTNULL,
CONSTRAINTPK_BBSRefTab
PRIMARYKEYNONCLUSTERED(MsgID)
)
go
-----------------
存储历程:
-----------------
--抽出
CREATEPROCEDUREsp_Summary
@HaveBodybit,
@fromnumeric,
@tonumeric
AS
IF(@HaveBody=1)
selectt.ID,t.DateAndTime,m.Nicknameas
Author,m.Email,t.Subject,t.Body,t.LinkURL,t.TextForLink,t.ImageURL,s.ChildNu
m,s.ParentID
fromMessaget
,MsgRefTabASs
,(SELECTMsgIDFROMMsgRefTabWHEREParentID=0)ASf
,MembersASm
wheret.ID=s.MsgID
andf.MsgID=s.AncestorID
andf.MsgIDbetween@fromand@to
andm.MemberID=t.AuthorID
orderbys.AncestorID,s.LinkStr
ELSE
selectt.ID,t.DateAndTime,m.Nicknameas
Author,m.Email,t.Subject,t.LinkURL,t.TextForLink,t.ImageURL,s.ChildNum,s.Par
entID
fromMessaget
,MsgRefTabASs
,(SELECTMsgIDFROMMsgRefTabWHEREParentID=0)ASf
,MembersASm
wheret.ID=s.MsgID
andf.MsgID=s.AncestorID
andf.MsgIDbetween@fromand@to
andm.MemberID=t.AuthorID
orderbys.AncestorID,s.LinkStr
go

--加贴

CREATEPROCEDUREsp_Add_Message
@AuthorIDnumeric,
@Subjectnvarchar(250),
@Bodyntext,
@LinkURLnvarchar(100),
@TextForLinknvarchar(50),
@ImageURLnvarchar(100),
@ParentIDnumeric,
@IDnumericOUTPUT,
@ChildNumnumericOUTPUT,
@LinkStrnvarchar(250)OUTPUT,
@AncestorIDnumericOUTPUT
AS
INSERTINTOMessage(
AuthorID,
Subject,
Body,
LinkURL,
TextForLink,
ImageURL)
VALUES(
@AuthorID,
@Subject,
@Body,
@LinkURL,
@TextForLink,
@ImageURL)

SELECT@ID=@@IDENTITY

UPDATEMsgRefTab
SET
ChildNum=ChildNum+1
WHERE
MsgID=@ParentID

SELECT@ChildNum=ChildNum,
@LinkStr=LinkStr,
@AncestorID=</p>强大的可扩展性。ASP具有强大的扩展性,可以实现与多种网络、硬件设备的连接:通过专用的通讯线路远程接入企业;通过远程拨号服务器为远程拨号客户提供服务;通过WAP为移动电话互联网客户服务。
变相怪杰 该用户已被删除
沙发
发表于 2015-1-18 11:03:37 | 只看该作者
另外因为asp需要使用组件,所以了解一点组件的知识(ADODB也是组件)
冷月葬花魂 该用户已被删除
板凳
发表于 2015-1-21 19:40:58 | 只看该作者
接下来就不能纸上谈兵了,最好的方法其实是实践。实践,只能算是让你掌握语言特性用的。而提倡做实际的Project也不是太好,因为你还没有熟练的能力去综合各种技术,这样只能使你自己越来越迷糊。
若天明 该用户已被删除
地板
发表于 2015-1-30 17:19:04 | 只看该作者
下载一个源代码,然后再下载一个VBScript帮助,在源代码中遇到不认识的函数或是其他什么程序,都可以查帮助进行解决,这样学习效率很高。
乐观 该用户已被删除
5#
发表于 2015-1-30 19:21:50 | 只看该作者
最近在学asp,不要问我为什么不直接学.net,因为公司网站是asp做的所以有这个需要,卖了本书asp入门到精通,对里面的六大内置对象老是记不住,还有很多属性和方法看的头晕。
愤怒的大鸟 该用户已被删除
6#
发表于 2015-2-2 11:21:44 | 只看该作者
ASP主要是用好六个对象,其实最主要的是用好其中两个:response和request,就可以随心所欲地控制网页变换和响应用户动作了。
山那边是海 该用户已被删除
7#
发表于 2015-2-7 18:47:40 | 只看该作者
多看多学多思。多看一些关于ASP的书籍,一方面可以扩展知识面一方面可以鉴借别人是如何掌握、运用ASP的;多学善于关注别人,向同学老师多多学习,不论知识的大小;多思则是要将学到的知识灵活运用。
蒙在股里 该用户已被删除
8#
发表于 2015-2-22 22:47:58 | 只看该作者
我想问如何掌握学习节奏(先学什么再学什么)最好详细点?
分手快乐 该用户已被删除
9#
 楼主| 发表于 2015-3-7 04:01:22 | 只看该作者
掌握asp的特性而且一定要知道为什么。
爱飞 该用户已被删除
10#
发表于 2015-3-14 09:06:38 | 只看该作者
兴趣爱好,那么你无须学编程,申请一个域名和空间,在网上下载一些免费开源的CMS系统,你不用改代码,只须熟悉它们的后台操作,像office一样简单方便,很快就能建一个站点,很多站长都是这样做的
小妖女 该用户已被删除
11#
发表于 2015-3-21 01:33:09 | 只看该作者
下载一个源代码,然后再下载一个VBScript帮助,在源代码中遇到不认识的函数或是其他什么程序,都可以查帮助进行解决,这样学习效率很高。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-12 07:17

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表