亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

EF結合SqlBulkCopy在項目中的使用

2019-11-14 16:09:57
字體:
來源:轉載
供稿:網友

這是我第一次寫博客,由于水平有限,寫不出什么好東西,還望見諒。

我現在參與的這個項目采用的是EF框架,方便了數據庫的訪問。但在實際中,發現項目中導入市縣Excel數據耗時太長,于是趁這段時間專門研究了一下大數據的導入。

Excel數據如圖:

 

項目數據庫里已經有了省市數據,任務是導入縣數據。其中省市縣之間有外鍵關系。項目里已經有了讀取Excel表的方法,而且效率不低,耗時主要是在導入到Sql Server2008中

 

public void ImportCounties(List<County> counties)

        {

            List<City> cities = counties.Select(d => d.City).ToList();

            MyTestEntities db = new MyTestEntities();

            foreach (var city in cities)

            {

                PRovince province =

                    db.Provinces.Where(d => d.Name == city.Province.Name).First();

                city.Province = province;

            }

 

            foreach (var county in counties)

            {

                db.Counties.AddObject(county);

            }

 

 

            db.SaveChanges();

        }

這是項目里的源代碼,耗時40秒左右。我測試之后發現不僅效率低,而且是有bug的。測試時第一次錄入數據沒問題,如果刪除Counties表里的數據再導入數據是有問題的,我不知道為什么要為Province賦值而且第一次可以成功,如果有大神看見,請幫我解惑。我只能先嘗試以我的方法去做。

 

 

public void ImportCountiesSecond(List<County> counties)

        {

            MyTestEntities db = new MyTestEntities();

 

            List<City> cities = db.Cities.ToList();

            foreach (var county in counties)

            {

                county.City = cities.Where(d => d.Name == county.City.Name).FirstOrDefault();

                db.Counties.AddObject(county);

            }

 

 

            db.SaveChanges();

        }

速度大概縮減到20秒,但這也不是我所能忍受的。于是上網又查了資料,了解到SqlBulkCopy。

代碼如下:

 

 

public void ImportCountiesThird(List<County> counties)

        {

            MyTestEntities db = new MyTestEntities();

            string conStr = ConfigurationManager.ConnectionStrings["dbConnStr"].ConnectionString;

            List<City> cities = db.Cities.ToList();

            DataTable table = new DataTable();

            table.Columns.Add("CityId", typeof(int));

            table.Columns.Add("Name");

            table.Columns.Add("OrderNum", typeof(int));

            table.Columns.Add("IsCity", typeof(bool));

            for (int i = 0; i < counties.Count; i++)

            {

                County line = counties[i];

                int cityId = cities.Where(d => d.Name == counties[i].City.Name).FirstOrDefault().CityId;

                string name = line.Name;

                int orderNum = line.OrderNum;

                bool isCity = line.IsCity;

 

                DataRow row = table.NewRow();

                row["CityId"] = cityId;

                row["Name"] = name;

                row["OrderNum"] = orderNum;

                row["IsCity"] = isCity;

                table.Rows.Add(row);

            }

            using (SqlBulkCopy bulkCopy = new SqlBulkCopy(conStr))

            {

                bulkCopy.DestinationTableName = "Counties";

                bulkCopy.ColumnMappings.Add("CityId", "CityId");

                bulkCopy.ColumnMappings.Add("Name", "Name");

                bulkCopy.ColumnMappings.Add("OrderNum", "OrderNum");

                bulkCopy.ColumnMappings.Add("IsCity", "IsCity");

                bulkCopy.WriteToServer(table);

            }

        }

時間縮減到4秒左右,其中主要是在EF查詢City表并為每一個Counties賦值時耗時占了大半。但這個的優化我覺得暫時做不到了,先這樣吧。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美肥老太性生活视频| 国产精品永久免费观看| 欧美在线视频导航| 日本道色综合久久影院| 亚洲一区制服诱惑| 欧美巨乳在线观看| 欧美日韩在线免费观看| 久久综合网hezyo| 亚洲欧美国产va在线影院| 2019中文在线观看| 中文字幕久久亚洲| 欧美视频二区36p| 狠狠色狠色综合曰曰| 久久手机免费视频| 97成人精品区在线播放| 久久亚洲精品网站| 国产激情综合五月久久| 九九热这里只有精品6| 亚洲精品自在久久| 91在线视频免费| 青青a在线精品免费观看| 97av在线影院| 国产免费久久av| 国产va免费精品高清在线观看| 国产suv精品一区二区三区88区| 日韩精品高清在线| 中文字幕精品av| 久久中文字幕在线视频| 亚洲性线免费观看视频成熟| 97精品国产97久久久久久免费| 91高清视频免费| 日韩在线欧美在线国产在线| 欧美情侣性视频| 亚洲一级一级97网| 国产欧美日韩最新| 亚洲毛片一区二区| 91在线观看免费网站| 久久精品成人一区二区三区| 欧美亚洲国产另类| 日韩a**站在线观看| 亚洲国产成人在线视频| 精品久久在线播放| 成人免费在线视频网址| 国产亚洲精品成人av久久ww| 亚洲天堂影视av| 国产精品高清网站| 国产精品入口免费视| 久久99久久99精品免观看粉嫩| 国产精品小说在线| 亚洲电影第1页| 国产综合在线观看视频| 亚洲成人黄色在线观看| 国产精品久久久久久久久久小说| 国产日韩欧美在线视频观看| 欧美精品生活片| 一区二区三区www| 日韩电影免费观看在线观看| 神马国产精品影院av| 欧美性高潮在线| 欧美日韩国产精品一区二区不卡中文| 成人h视频在线观看播放| 91在线|亚洲| 国产一区二区黑人欧美xxxx| 亚洲国产精品久久久久久| 福利微拍一区二区| 国产精品激情av在线播放| 日韩欧美在线观看| 日韩专区中文字幕| 欧美第一黄色网| 日韩美女免费观看| 久久视频中文字幕| 国产精品丝袜视频| 91九色蝌蚪国产| 亚洲色图15p| 久久国产精品免费视频| 亚洲精品久久久久| 欧美中文在线观看| 欧美激情一区二区久久久| 夜色77av精品影院| 97在线视频观看| 色妞在线综合亚洲欧美| 91免费人成网站在线观看18| 国产成人福利夜色影视| 欧美激情一区二区三区久久久| 久久精品国产v日韩v亚洲| 性欧美办公室18xxxxhd| 国内精品久久久久久久| 在线观看精品自拍私拍| 国产福利精品在线| www日韩中文字幕在线看| 狠狠综合久久av一区二区小说| 欧美电影在线观看完整版| 久久99精品视频一区97| 91大神在线播放精品| 亚洲a级在线播放观看| 神马国产精品影院av| 欧美日韩色婷婷| 亚洲综合在线小说| 亚洲欧美日韩第一区| 97久久国产精品| 日韩经典第一页| 欧美性猛交xxxxx水多| 92国产精品久久久久首页| 国产成人精品在线| 精品国产一区二区在线| 欧美极品美女电影一区| 国产精品视频午夜| 亚洲视频在线看| 亚洲人成在线观看| 久久不射热爱视频精品| 日韩欧美福利视频| 国产香蕉精品视频一区二区三区| 91精品国产综合久久久久久久久| 8x海外华人永久免费日韩内陆视频| 日韩一区在线视频| 日韩福利视频在线观看| 日韩在线观看免费全| 久久久亚洲国产| 欧美一区二区大胆人体摄影专业网站| 国产精品1区2区在线观看| 欧美亚洲另类制服自拍| 久久久久久久电影一区| 国内精品国产三级国产在线专| 在线午夜精品自拍| 91久久久久久久久久久| 国产91av在线| 国产91热爆ts人妖在线| 欧美激情精品久久久久久变态| 夜夜嗨av一区二区三区免费区| 亚洲成avwww人| 国产亚洲欧美另类中文| 久久露脸国产精品| 日韩小视频在线| 亚洲精品福利资源站| 久久久久久久久久婷婷| 欧美午夜片在线免费观看| 在线激情影院一区| 国产欧美日韩专区发布| 精品日韩美女的视频高清| 国产精品视频yy9099| 亚洲视频网站在线观看| 日韩成人中文字幕| 精品久久久国产精品999| 国产www精品| 久久91亚洲精品中文字幕| 亚洲精品理论电影| 亚洲欧美变态国产另类| 国产成人在线精品| 久久精品一本久久99精品| 亚洲无限av看| 大胆欧美人体视频| 亚洲福利在线播放| 成人黄色午夜影院| 日韩亚洲国产中文字幕| 欧美成人免费观看| 午夜精品久久久久久久白皮肤| 亚洲欧美激情精品一区二区| 97视频在线观看免费高清完整版在线观看| 91久久综合亚洲鲁鲁五月天| 欧美中文字幕视频| 日本中文字幕不卡免费| 国产成人自拍视频在线观看| 国产精品视频色| 色噜噜亚洲精品中文字幕|