日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

C#在Entity?Framework中實現事務回滾_C#教程

作者:Darren?Ji ? 更新時間: 2022-10-23 編程語言

在使用Entity Framework為主從表添加數據,當一個表添加數據成功,另一個表添加數據失敗,這時候就需要用到事務回滾。

比如有以下關系的2張表。

客戶端使用TransactionScope類可以實現事務回滾。

    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                using (TransactionScope ts = new TransactionScope())
                {
                    using (CountryDetailsEntities db = new CountryDetailsEntities())
                    {
                        Country country = new Country();
                        country.CountryName = "USA";
                        db.Countries.Add(country);
                        db.SaveChanges();
                        if (country.CountryID > 0)
                        {
                            int a = 0;
                            int total = 10 / a;
                            State state = new State();
                            state.CountryID = country.CountryID;
                            state.StateName = "NewYork";
                            db.States.Add(state);
                            db.SaveChanges();
                        }
                    }
                    ts.Complete();
                }
                
            }
            catch (Exception ex)
            {
                throw;
            }
        }
    }

以上,在添加State表數據的時候,模擬了一個異常,通過斷點調試執行完畢,發現數據庫中沒有增加任何數據。

原文鏈接:https://www.cnblogs.com/darrenji/p/3965233.html

欄目分類
最近更新