|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
ASP由于使用了COM组件所以它会变的十分强大,但是这样的强大由于WindowsNT系统最初的设计问题而会引发大量的安全问题。只要在这样的组件或是操作中一不注意,哪么外部攻击就可以取得相当高的权限而导致网站瘫痪或者数据丢失;存储历程|分页/*****听之前的同事说asp页面上的分页太慢了(假如数据多了),
就想了这么个笨举措。有些中央还要思索----好比selecttop22*fromcat_list
whereT_idnotin(selectT_idfrom#change)是不是无效率成绩;数据不克不及反复等等
不外天真性挺好。但愿列位妙手再给协助更正;多谢chair3的匡助---这个存储历程还能够在到场几个变量,任意人人改吧:)*****/
CREATEprocpage
@pagenumint
as
SETNOCOUNTON/*-----这一句很主要哦:)),否则它只会认insert#change......这个数据集:))*/
declare@sqlnvarchar(500)--声明静态sql实行语句
declare@pagecountint--以后页数
--获得以后数据库的纪录总数
declare@row_numint
begin
select@row_num=count(*)fromcat_list
--创立一时表,作为数据过滤
createtable#change(T_idint)
--判别以后页数
if@row_num>6--年夜于页面显现纪录数,则分页
begin
set@row_num=@pagenum*6
if@row_num=6
selecttop6*fromcat_list
else
begin
set@row_num=(@pagenum-1)*6
set@pagecount=@row_num
set@sql=Ninsert#change(T_id)selecttop+cast(@pagecountaschar(100))+T_idfromcat_listwhereT_idnotin(selectT_idfrom#change)
execsp_executesql@sql
selecttop6*fromcat_listwhereT_idnotin(selectT_idfrom#change)
end
end
else--只实际全体的数据
select*fromcat_list
end
GO
客户端如许挪用:
<!--#includefile="conn.asp"-->
<!--#includefile="adovbs.inc"-->
<%dimT_com
dimT_rsdeclaredatamanagerecordset
dimparameters
setT_com=server.createobject("adodb.command")
T_com.ActiveConnection=conn
T_com.CommandText="page"
T_com.CommandType=adCmdStoredProc
T_com.Prepared=true
setparameters=T_com.CreateParameter("@pagenum",adInteger,adParamInput)
T_com.Parameters.Appendparameters
dimpage
page=request.QueryString("page")
ifpage=""then
page=1
endif
T_com("@pagenum")=page
setT_rs=T_com.Execute
dowhilenotT_rs.eof
response.WriteT_rs("c_name")
T_rs.movenext
loop
%>
<ahref="a.asp?page=<%=page+1%>">ddddd</a></p>asp对于服务器的要求较高,一般的服务器如果访问量一大就垮了,不得不重启。 |
|