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

时间:2010-12-21 15:57:20

标签: sqlite xamarin.ios

好的,这可能是非常基本的东西,但我花了很长时间才弄明白。我想有更多像我这样的.NET程序员,Monotouch和SQLite的新手都不知道。

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

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

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

1 个答案:

答案 0 :(得分:7)

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();
        }
    }

或者您可以将select与插入结合起来,例如:

string SqlCommand = "INSERT into Customers ([Name], .... [City]) VALUES (@Name, ... @City);SELECT last_insert_rowid();";