【发布时间】:2012-02-06 23:19:24
【问题描述】:
是否可以在 SaveChanges 方法之后但在使用 DbContext 调用 TransactionScope.Complete 之前获取记录的标识?我们是否需要强制转换为 ObjectContext 才能获得此功能?
当我们使用 MSDTC 将消息发送到单独服务器上的事务队列时,我们需要它。
例子:
static void Main(string[] args)
{
const string qName = ".\\Private$\\DbContextTransactions";
var db = new BlogDb();
// force db creation & create queue
Console.WriteLine("Count={0}", db.Posts.Count());
if (!MessageQueue.Exists(qName))
MessageQueue.Create(qName, true); // transactional
try
{
using (var t = new TransactionScope())
using (MessageQueue q = new MessageQueue(qName))
{
var post = new Post() { Title = "Test " + DateTime.Now.Ticks.ToString() };
db.Posts.Add(post);
db.SaveChanges();
// TODO: how do we get post.Id (updated identity)?
q.Send(post.Id, MessageQueueTransactionType.Automatic);
t.Complete();
}
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
Console.WriteLine("Count={0}", db.Posts.Count());
Console.ReadLine();
}
【问题讨论】:
-
调用
SaveChanges后,您的 post.Id 应填写数据库中的正确身份。 -
我们在连接字符串中发现了“enlist=false”,这导致我们的事务无法登记。
标签: entity-framework transactions ef-code-first transactionscope