Monotouch上的Mono.Data.Sqlite:如何在插入行后获取自动增量字段的值?

Monotouch上的Mono.Data.Sqlite:如何在插入行后获取自动增量字段的值?,第1张

概述好吧,这可能是非常基本的东西,但我花了很长时间才弄明白.我想有更多像我这样的.NET程序员,Monotouch和SQLite的新手都不知道这一点. 我将Ado.NET(System.Data)与Monotouch和SQLite一起使用.在SQLite中,每个表的每一行都有一个名为ROWID的64位有符号整数.您可以使用它,或者如果您愿意,可以使用INTEGER PRIMARY KEY AUTOIN 好吧,这可能是非常基本的东西,但我花了很长时间才弄明白.我想有更多像我这样的.NET程序员,Monotouch和sqlite的新手都不知道这一点.

我将Ado.NET(System.Data)与Monotouch和sqlite一起使用.在sqlite中,每个表的每一行都有一个名为ROWID的64位有符号整数.您可以使用它,或者如果您愿意,可以使用INTEGER PRIMARY KEY autoINCREMENT指定一个字段,sqlite将链接到ROWID.

但是,如何在插入新记录后检索此字段的值?像sql Server中的@@ IDentity关键字?

搜索我发现sqlite的iOS库有一个方法sqlite3_last_insert_rowID()来检索它,但在Mono.Data.sqlite中没有相应的.在较旧的实现(Mono.Data.sqliteClIEnt)中有一个LastInsertRowID()方法,但该方法在Mono.Data.sqlite中消失了.为什么?

解决方法 sqlite有一些内部 core functions.其中一个函数是last_insert_rowID().因此,您所要做的就是发出命令“SELECT last_insert_rowID()”. Monotouch中的示例:

public long GetLastInsertRowID(sqliteConnection connection)    {        // Assuming connection is an open connection from your INSERT        using (sqliteCommand command = new sqliteCommand("SELECT last_insert_rowID()",connection))        {            return (long)command.ExecuteScalar();        }    }

或者您可以将选择与插入组合,例如:

string sqlCommand = "INSERT into Customers ([name],.... [City]) VALUES (@name,... @City);SELECT last_insert_rowID();";
总结

以上是内存溢出为你收集整理的Monotouch上的Mono.Data.Sqlite:如何在插入行后获取自动增量字段的值?全部内容,希望文章能够帮你解决Monotouch上的Mono.Data.Sqlite:如何在插入行后获取自动增量字段的值?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1156088.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存