加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 18:57:47 所属栏目:百科 来源:网络整理
导读:好吧,这可能是非常基本的东西,但我花了很长时间才弄明白.我想有更多像我这样的.NET程序员,Monotouch和SQLite的新手都不知道这一点. 我将Ado.NET(System.Data)与Monotouch和SQLite一起使用.在SQLite中,每个表的每一行都有一个名为ROWID的64位有符号整数.您可
好吧,这可能是非常基本的东西,但我花了很长时间才弄明白.我想有更多像我这样的.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();";

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读