好吧,这可能是非常基本的东西,但我花了很长时间才弄明白.我想有更多像我这样的.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();";