是否可以在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();
}
答案 0 :(得分:2)
在致电SaveChanges
后,即使在TransactionScope
内,也应始终设置身份值。