Access中的SELECT @@IDENTITY
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Access中的SELECT @@IDENTITY,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1507字,纯文字阅读大概需要3分钟。
内容图文
![Access中的SELECT @@IDENTITY](/upload/InfoBanner/zyjiaocheng/1333/1e2609fdd73648999420ad73e319db20.jpg)
在Access数据库中存在select @@identity吗?答案是肯定的。但是Access一次只能执行一条SQL,多条SQL需要多次执行,这是限制。在SQL Server中,可以一次执行多条SQL语句。Access使用的是Jet-SQL,SQL Server使用的是T-SQL,两者用法上相差很大。
但是Access中可以连续执行N条语句,象下面这样:
cmd.CommandText = "INSERT INTO MyTable (N1,N2) VALUES (22,11)";
int count = cmd.ExecuteNonQuery();
cmd.CommandText = "SELECT @@IDENTITY";
int newId = (int)cmd.ExecuteScalar();
其中SELECT @@IDENTITY是取出前一条语句的自动编号的关键字。
在Sql Server中可以用ExecuteReader()来同时执行几条一起的Sql语句
PetShop 4.0中有如下用法:
using (SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection)) {
// Read the returned @ERR
rdr.Read();
// If the error count is not zero throw an exception
if (rdr.GetInt32(1) != 0)
throw new ApplicationException("DATA INTEGRITY ERROR ON ORDER INSERT - ROLLBACK ISSUED");
}
其中cmd对象的Sql语句如下所示(我在调试中取出来的):
Declare @ID int;
Declare @ERR int;
INSERT INTO Orders VALUES
(@UserId, @Date, @ShipAddress1, @ShipAddress2, @ShipCity, @ShipState, @ShipZip, @ShipCountry, @BillAddress1, @BillAddress2, @BillCity, @BillState, @BillZip, @BillCountry, ‘UPS‘, @Total, @BillFirstName, @BillLastName, @ShipFirstName, @ShipLastName, @AuthorizationNumber, ‘US_en‘);
SELECT @ID=@@IDENTITY;
INSERT INTO OrderStatus VALUES(@ID, @ID, GetDate(), ‘P‘);
SELECT @ERR=@@ERROR;
INSERT INTO LineItem VALUES( @ID, @LineNumber0, @ItemId0, @Quantity0, @Price0);
SELECT @ERR=@ERR+@@ERROR;
INSERT INTO LineItem VALUES( @ID, @LineNumber1, @ItemId1, @Quantity1, @Price1);
SELECT @ERR=@ERR+@@ERROR;
SELECT @ID, @ERR
原文:http://www.cnblogs.com/zywf/p/4644068.html
内容总结
以上是互联网集市为您收集整理的Access中的SELECT @@IDENTITY全部内容,希望文章能够帮你解决Access中的SELECT @@IDENTITY所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。