首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 软件教学-> 图文处理
使用SQL存储过程要特别注意的问题-注意顺序读取-数据库专栏,SQL Server
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
    存储过程是一个运行于sql数据库之中最核心的事务,它通过长驻内存的形式,进行读取\处理\写入最为频繁处理的数据.
    asp虽然在微软的aspx的侵袭下,仍旧是中小企业继续在用的一种网页语言,但是当要读取海量数据的时候,如果仍旧使用普通的sql进行读取运行与写入,将导致系统资源的严重浪费,所以我们在asp中使用存储过程,以提高数据的存取速度,同时通过sql核心的获取数据的方法,可以有效的减少垃圾数据(不被立即使用,而且也不备较短的时间里被使用的数据)操作.
    在asp中使用存储过程也是相当的容易,例如以下一个通过sql存储过程进行分页的方法:
存储过程:
create procedure p_splitpage   
@sql nvarchar(4000), --要执行的sql语句
@page int=1,    --要显示的页码
@pagesize int,  --每页的大小
@pagecount int=0 out, --总页数
@recordcount int=0 out --总记录数
as
set nocount on
declare @p1 int
exec sp_cursoropen @p1 output,@sql,@scrollopt=1,@ccopt=1,@rowcount=@pagecount output
set @recordcount = @pagecount
select @pagecount=ceiling(1.0*@pagecount/@pagesize)
 ,@page=(@page-1)*@pagesize+1
exec sp_cursorfetch @p1,16,@page,@pagesize 
exec sp_cursorclose @p1
go
asp页面的内容
sql = "select id, c_s_name from tabnews where deleted<>1 order by id desc"
page = cint(page_get)
if page_post<>""then
 page = cint(page_post)
end if
if not page > 0 then 
 page = 1
end if
pagesize=20’每页的条数
set cmd = server.createobject("adodb.command")
cmd.activeconnection = conn
cmd.commandtype = 4
cmd.commandtext = "p_splitpage"
cmd.parameters.append cmd.createparameter("@sql",8,1, 4000, sql)
cmd.parameters.append cmd.createparameter("@page",4,1, 4, page)
cmd.parameters.append cmd.createparameter("@pagesize",4,1, 4, pagesize)
cmd.parameters.append cmd.createparameter("@pagecount",4,2, 4, pagecount)
cmd.parameters.append cmd.createparameter("@recordcount",4,2, 4, recordcount)
set rs = cmd.execute
set rs = rs.nextrecordset
pagecount = cmd.parameters("@pagecount").value
recordcount = cmd.parameters("@recordcount").value
if pagecount = 0 then pagecount = 1
if page>pagecount then 
 response.redirect("?page="&pagecount) 
end if
set rs = cmd.execute
    我们如此就可以实现对数据的读取并可以进行有效的分页,但是我们往往会发现一个问题,如果我们构造的sql语句如果使用的是select * from tab ...的话,就经常出现无法读取数据的错误,或者是读取出来,但是有的数据无法显示的错误,经过仔细的检查发现,如果是排列在sql语句的前列的数据可以被读取,而如果不按照sql读取出来的字段进行顺序读取,就会出现数据丢失的情况,所以唯一的途径就是进行顺序读取.如:
    对于select id, newstitle, newscontent from tabnews where ...的sql语句,就应当将所有的数据读取到变量上来,并且要求是按照sql语句的顺序进行读取,然后这些数据就可以自由的使用了.
    id = rs("id")
    newstitle = rs("newstitle")
    ...
    分析出现这个的原因是:sql数据库在构造虚拟表的时候就是以一种先进先出的原则,把所有的数据排列在一个内存段之中,通过顺序的读取,将数据逐一的读取,而如果跳过某个具体的字段获取下一个字段的信息,系统就会将原来的那个字段的信息丢失,以释放内存,这是出于系统构造的简单性和系统的内存最低化的要求,所以这样也保证了有限的内存资源得到最充分的发挥,这也是为什么存储过程比普通的sql要快的原因.
文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Java Reflection (JAVA反射)-JSP教程,Java技巧及代码
·WebServices入门-.NET教程,Web Service开发
·如何在c#中使用mapx5.0(二)-.NET教程,C#语言
·用java启动记事本程序,并输入内容-JSP教程,Java技巧及代码
·正则表达式-ASP教程,正则表达式
·sql server中的外键约束-数据库专栏,SQL Server
·java中的基于套结字(socket)的通信 一. 一个双人单方向通信例子-JSP教程,Java技巧及代码
·图解利用Eclipse3+Lomboz3+Tomcat开发JSP --1.环境-JSP教程,Jsp/Servlet
·EditPlus+NAnt构建轻巧的.NET开发环境-.NET教程,Asp.Net开发
·ASP.NET2.0下利用javascript实现TreeView中的checkbox全选-.NET教程,Asp.Net开发
最新文章
·photoshop简单为美女照片瘦身及调色_photoshop教程
·fireworks巧绘精美可爱水杯图标_fireworks教程
·如何修复windows vista系统用户损坏的配置文件_windows vista
·本地门户营运的3个重点注意事项_站长心得
·必知:在线推广网站的十四种方法_站长心得
·google analytics统计分析新版本说明_google推广
·google adsense 违规行为集_google推广
·googleadsense的无效点击_google推广
·关于网络原创作品的版权问题_网络编辑
·符合xhtml标准div+css布局的网站对网站seo的影响_seo网站优化
相关主题
  • 使用sql语句获取sql server数据库登录用户权限_数据库技巧
  • 使用sql server 2005中的clr集成_数据库技巧
  • 使用sqlserver的扩展存储过程实现远程备份与恢复_delphi教程
  • 使用SqlDataReader读取数据示例-.NET教程,数据库应用
  • 使用SQL语句取消SQL Server数据库登录用户权限-数据库专栏,SQL Server
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭