<bdo id='jE3AS'></bdo><ul id='jE3AS'></ul>

    1. <i id='jE3AS'><tr id='jE3AS'><dt id='jE3AS'><q id='jE3AS'><span id='jE3AS'><b id='jE3AS'><form id='jE3AS'><ins id='jE3AS'></ins><ul id='jE3AS'></ul><sub id='jE3AS'></sub></form><legend id='jE3AS'></legend><bdo id='jE3AS'><pre id='jE3AS'><center id='jE3AS'></center></pre></bdo></b><th id='jE3AS'></th></span></q></dt></tr></i><div id='jE3AS'><tfoot id='jE3AS'></tfoot><dl id='jE3AS'><fieldset id='jE3AS'></fieldset></dl></div>
    2. <tfoot id='jE3AS'></tfoot>
    3. <legend id='jE3AS'><style id='jE3AS'><dir id='jE3AS'><q id='jE3AS'></q></dir></style></legend>

        <small id='jE3AS'></small><noframes id='jE3AS'>

        如何从 SQLite 表中检索最后一个自动递增的 ID?

        How to retrieve the last autoincremented ID from a SQLite table?(如何从 SQLite 表中检索最后一个自动递增的 ID?)

        <tfoot id='IaC0D'></tfoot>
            <tbody id='IaC0D'></tbody>
          • <bdo id='IaC0D'></bdo><ul id='IaC0D'></ul>
            <legend id='IaC0D'><style id='IaC0D'><dir id='IaC0D'><q id='IaC0D'></q></dir></style></legend>
          • <i id='IaC0D'><tr id='IaC0D'><dt id='IaC0D'><q id='IaC0D'><span id='IaC0D'><b id='IaC0D'><form id='IaC0D'><ins id='IaC0D'></ins><ul id='IaC0D'></ul><sub id='IaC0D'></sub></form><legend id='IaC0D'></legend><bdo id='IaC0D'><pre id='IaC0D'><center id='IaC0D'></center></pre></bdo></b><th id='IaC0D'></th></span></q></dt></tr></i><div id='IaC0D'><tfoot id='IaC0D'></tfoot><dl id='IaC0D'><fieldset id='IaC0D'></fieldset></dl></div>

                1. <small id='IaC0D'></small><noframes id='IaC0D'>

                  本文介绍了如何从 SQLite 表中检索最后一个自动递增的 ID?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我有一个表消息,其中包含列 ID(主键、自动增量)和内容(文本).
                  我有一个表用户,其中包含用户名(主键、文本)和哈希列.
                  一条消息由一个发送者(用户)发送给多个接收者(用户),一个接收者(用户)可以有很多条消息.
                  我创建了一个包含两列的 Messages_Recipients 表:MessageID(指的是 Messages 表的 ID 列和 Recipient(指的是 Users 表中的 username 列).该表表示收件人和消息之间的多对多关系.

                  所以,我的问题是这个.新消息的 ID 将在它存储在数据库中后创建.但是我如何保存对刚刚添加的 MessageRow 的引用以检索这个新的 MessageID?
                  当然,我总是可以在数据库中搜索添加的最后一行,但这可能会在多线程环境中返回不同的行吗?

                  I have a table Messages with columns ID (primary key, autoincrement) and Content (text).
                  I have a table Users with columns username (primary key, text) and Hash.
                  A message is sent by one Sender (user) to many recipients (user) and a recipient (user) can have many messages.
                  I created a table Messages_Recipients with two columns: MessageID (referring to the ID column of the Messages table and Recipient (referring to the username column in the Users table). This table represents the many to many relation between recipients and messages.

                  So, the question I have is this. The ID of a new message will be created after it has been stored in the database. But how can I hold a reference to the MessageRow I just added in order to retrieve this new MessageID?
                  I can always search the database for the last row added of course, but that could possibly return a different row in a multithreaded environment?

                  据我了解,对于 SQLite,您可以使用 SELECT last_insert_rowid().但是我如何从 ADO.Net 调用这个语句?

                  As I understand it for SQLite you can use the SELECT last_insert_rowid(). But how do I call this statement from ADO.Net?

                  我的持久化代码(消息和消息接收者是数据表):

                  My Persistence code (messages and messagesRecipients are DataTables):

                  public void Persist(Message message)
                  {
                      pm_databaseDataSet.MessagesRow messagerow;
                      messagerow=messages.AddMessagesRow(message.Sender,
                                              message.TimeSent.ToFileTime(),
                                              message.Content,
                                              message.TimeCreated.ToFileTime());
                      UpdateMessages();
                      var x = messagerow;//I hoped the messagerow would hold a
                      //reference to the new row in the Messages table, but it does not.
                      foreach (var recipient in message.Recipients)
                      {
                          var row = messagesRecipients.NewMessages_RecipientsRow();
                          row.Recipient = recipient;
                          //row.MessageID= How do I find this??
                          messagesRecipients.AddMessages_RecipientsRow(row);
                          UpdateMessagesRecipients();//method not shown
                      } 
                  
                  }
                  
                  private void UpdateMessages()
                  {
                      messagesAdapter.Update(messages);
                      messagesAdapter.Fill(messages);
                  }
                  

                  推荐答案

                  使用 SQL Server,您将 SELECT SCOPE_IDENTITY() 获取当前进程的最后一个标识值.

                  With SQL Server you'd SELECT SCOPE_IDENTITY() to get the last identity value for the current process.

                  使用 SQlite,它看起来就像你会做的自动增量

                  With SQlite, it looks like for an autoincrement you would do

                  SELECT last_insert_rowid()
                  

                  在您插入后立即.

                  http://www.mail-archive.com/sqlite-users@sqlite.org/msg09429.html

                  在回答您的评论以获得此值时,您需要使用 SQL 或 OleDb 代码,例如:

                  In answer to your comment to get this value you would want to use SQL or OleDb code like:

                  using (SqlConnection conn = new SqlConnection(connString))
                  {
                      string sql = "SELECT last_insert_rowid()";
                      SqlCommand cmd = new SqlCommand(sql, conn);
                      conn.Open();
                      int lastID = (Int32) cmd.ExecuteScalar();
                  }
                  

                  这篇关于如何从 SQLite 表中检索最后一个自动递增的 ID?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  How can I schedule a job to run a SQL query daily?(如何安排作业每天运行 SQL 查询?)
                  How do I reset a sequence in Oracle?(如何在 Oracle 中重置序列?)
                  How to implement one-to-one, one-to-many and many-to-many relationships while designing tables?(设计表格时如何实现一对一、一对多和多对多的关系?)
                  Solutions for INSERT OR UPDATE on SQL Server(SQL Server 上 INSERT OR UPDATE 的解决方案)
                  Select first row in each GROUP BY group?(选择每个 GROUP BY 组中的第一行?)
                  Unable to CREATE TABLE; why does this code fail?(无法创建表;为什么这段代码会失败?)

                  1. <tfoot id='SqFPh'></tfoot>
                      • <bdo id='SqFPh'></bdo><ul id='SqFPh'></ul>
                          • <legend id='SqFPh'><style id='SqFPh'><dir id='SqFPh'><q id='SqFPh'></q></dir></style></legend>

                              <tbody id='SqFPh'></tbody>

                            <small id='SqFPh'></small><noframes id='SqFPh'>

                            <i id='SqFPh'><tr id='SqFPh'><dt id='SqFPh'><q id='SqFPh'><span id='SqFPh'><b id='SqFPh'><form id='SqFPh'><ins id='SqFPh'></ins><ul id='SqFPh'></ul><sub id='SqFPh'></sub></form><legend id='SqFPh'></legend><bdo id='SqFPh'><pre id='SqFPh'><center id='SqFPh'></center></pre></bdo></b><th id='SqFPh'></th></span></q></dt></tr></i><div id='SqFPh'><tfoot id='SqFPh'></tfoot><dl id='SqFPh'><fieldset id='SqFPh'></fieldset></dl></div>