首页  |  IT相关文档  |  工具软件  |  网站建设  |  程式开发  |  图形设计  |  操作系统  |  服务器类  |  数据库类  |  网络安全  |  网络技术  |  计算机应用  |  站长之家  |  网络游戏
 

热点文章

IT动态

·淘宝与日本雅虎强强联合推出跨国交
·2010年电子书迎来黄金年
·雅虎持巨资对抗谷歌推广
·从BT站点关闭到恢复看待网站转型
·微软Docs.com平台今日正式上线
·谷歌第一季度疯狂收购10家公司
·百度即将推出PC端输入法
·IE市场份额首次跌破60%
·赛迪澄清虚假上市公告
·Opera针对漏洞发布Win/Mac平台10.5
·看待google展示光纤速度
·站长应该抓住有效的长尾机会

GG搜索更多相关
 
当前位置:主页>程式开发>Asp.net教程>

提高SQL性能的好方法

来源: 作者: 发布时间:2010-04-17

LEFTJOIN、CROSSJOIN的使用以及IDENTITY值的检索。请记住,根本没有神奇的解决方案。调整您的数据库及其查询需要占用时间、进行分析,还需要大量的测试。这些技术都已被证明行之有效,但对您的应用程序而言,可能其中一些技术比另一些技术更适用。

从INSERT返回IDENTITY,我决定从遇到许多问题的内容入手:如何在执行SQLINSERT后检索IDENTITY值。通常,问题不在于如何编写检索值的查询,而在于在哪里以及何时进行检索。在SQLServer中,下面的语句可用于检索由最新在活动数据库连接上运行的SQL语句所创建的IDENTITY值:SELECT@@IDENTITY这个SQL语句并不复杂,但需要记住的一点是:如果这个最新的SQL语句不是INSERT,或者您针对非INSERTSQL的其他连接运行了此SQL,则不会获得期望的值。您必须运行下列代码才能检索紧跟在INSERTSQL之后且位于同一连接上的IDENTITY,如下所示:

INSERTINTOProducts(ProductName)VALUES('Chalk')
SELECT@@IDENTITY在一个连接上针对Northwind数据库运行这些查询将返回一个名称为Chalk的新产品的IDENTITY值。所
以,在使用ADO的VisualBasic?应用程序中,可以运行以下语句:

SetoRs=oCn.Execute("SETNOCOUNTON;INSERTINTOProducts_
(ProductName)VALUES('Chalk');SELECT@@IDENTITY")

lProductID=oRs(0)此代码告诉SQLServer不要返回查询的行计数,然后执行INSERT语句,并返回刚刚为这个新行创建的IDENTITY值。SETNOCOUNTON语句表示返回的记录集有一行和一列,其中包含了这个新的IDENTITY值。如果没有此语句,则会首先返回一个空的记录集(因为INSERT语句不返回任何数据),然后会返回第二个记录集,第二个记录集中包含IDENTITY值。这可能有些令人困惑,尤其是因为您从来就没有希望过INSERT会返回记录集。之所以会发生此情况,是因为SQLServer看到了这个行计数(即一行受到影响)并将其解释为表示一个记录集。因此,真正的数据被推回到了第二个记录集。当然您可以使用ADO中的NextRecordset方法获取此第二个记录集,但如果总能够首先返回该记录集且只返回该记录集,则会更方便,也更有效率。

评论 | 收藏 | | 打印 | 关闭
相关链接
     
 

Copyright 2006-2007 xhit.cn All Rights Reserved
有什么建议或意见请发信到admin@xhit.cn 皖ICP备07007336