我有一个带有列 ID(主键、自动增量)和内容(文本)的消息表。
我有一个包含用户名(主键、文本)和哈希列的用户表。
一条消息由一个发件人(用户)发送给多个收件人(用户),而一个收件人(用户)可以拥有多条消息。
我创建了一个包含两列的 Messages_Recipients 表:MessageID(指的是 Messages 表的 ID 列和 Recipient(指的是 Users 表中的用户名列)。该表表示收件人和消息之间的多对多关系。
所以,我的问题是这个。新消息的 ID 将在存储到数据库后创建。但是,为了检索这个新的 MessageID,我如何保存对刚刚添加的 MessageRow 的引用?
当然,我总是可以在数据库中搜索添加的最后一行,但这可能会在多线程环境中返回不同的行?
编辑:据我了解,对于 SQLite,您可以使用SELECT last_insert_rowid()
. 但是我如何从 ADO.Net 调用这个语句呢?
我的持久性代码(消息和消息接收者是数据表):
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);
}