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

Monotouch上的Mono.Data.Sqlite:插入行后如何获取自动增量字段的值?,sqlite,xamarin.ios,Sqlite,Xamarin.ios,好吧,这可能是很基本的东西,但我花了很长时间才弄明白。我猜还有更多像我这样的.NET程序员,刚接触Monotouch和SQLite的人不知道这一点 我将Ado.NET(System.Data)与Monotouch和SQLite结合使用。在SQLite中,每个表的每一行都有一个名为ROWID的64位有符号整数。您可以使用它,或者如果愿意,可以指定一个带有整型主键AUTOINCREMENT的字段,SQLite将链接到ROWID 但是,在插入新记录后,如何检索此字段的值?类似Sql Server中的@

好吧,这可能是很基本的东西,但我花了很长时间才弄明白。我猜还有更多像我这样的.NET程序员,刚接触Monotouch和SQLite的人不知道这一点

我将Ado.NET(System.Data)与Monotouch和SQLite结合使用。在SQLite中,每个表的每一行都有一个名为ROWID的64位有符号整数。您可以使用它,或者如果愿意,可以指定一个带有整型主键AUTOINCREMENT的字段,SQLite将链接到ROWID

但是,在插入新记录后,如何检索此字段的值?类似Sql Server中的@identity关键字

在四处搜索时,我发现SQLite的iOS c库有一个方法sqlite3_last_insert_rowid()来检索这个,但在Mono.Data.SQLite中没有等效的方法。在旧的实现(Mono.Data.SqliteClient)中有一个LastInsertRowID()方法,但该方法在Mono.Data.Sqlite中消失了。为什么?

SQLite有一些内部缺陷。其中一个函数是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();";

你可能想复制下面的答案,这样它就成为一个已回答的问题。谢谢米格尔,我已经把它分为一个问题和一个答案。