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方法获取此第二个记录集,但如果总能够首先返回该记录集且只返回该记录集,则会更方便,也更有效率。