激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - Queryable.Union 方法實現json格式的字符串合并的具體實例

Queryable.Union 方法實現json格式的字符串合并的具體實例

2019-11-19 13:35asp.net教程網 ASP.NET教程

這篇文章介紹了Queryable.Union 方法實現json格式的字符串合并的具體實例,有需要的朋友可以參考一下

1.在數據庫中以json字符串格式保存,如:[{"name":"張三","time":"8.592","area":"27.27033","conc":"4.12136"},{"name":"李四","time":"9.100","area":"56.21229","conc":"4.57692"}]

2.添加新內容后合并不相同的數據。如果name相同,以最新的數據替換原來的數據。

如:數據庫中原保存的數據是[{"name":"張三","time":"8.592","area":"27.27033","conc":"4.12136"},{"name":"李四","time":"9.100","area":"56.21229","conc":"4.57692"}]

新加的數據為[{"name":"張三","time":"12","area":"27.70533","conc":"4.12136"},{"name":"王五","time":"4","area":"77","conc":"8.788"}]

 則替換后的數據為[{"name":"張三","time":"12","area":"27.70533","conc":"4.12136"},{"name":"王五","time":"4","area":"77","conc":"8.788"},{"name":"李四","time":"9.100","area":"56.21229","conc":"4.57692"}]

代碼如下:

 

復制代碼代碼如下:


public void InsertOrUpdateOnlyItem(List<tblLims_Ana_LE_Import_Common> listLe)
        {
            var listLeInsert = new List<tblLims_Ana_LE_Import_Common>();
            var listLeUpdate = new List<tblLims_Ana_LE_Import_Common>();
            foreach (var le in listLe)
            {
                tblLims_Ana_LE_Import_Common model = le;
                var own = CurrentRepository.Find(a => a.fldTaskID == model.fldTaskID
                && a.fldBizCatID == model.fldBizCatID
                && a.fldItemCode == model.fldItemCode
                && a.fldNumber == model.fldNumber
                && a.fldSampleCode == model.fldSampleCode);
                if (own != null)
                {
                    var ser = new JavaScriptSerializer();

 

                    var listown = ser.Deserialize<List<Dictionary<string, string>>>(own.fldImportData);  //原數據
                    var listmodel = ser.Deserialize<List<Dictionary<string, string>>>(model.fldImportData); //新數據
                    IEqualityComparer<Dictionary<string, string>> ec = new EntityComparer();   //自定義的比較類
                    own.fldImportData = ser.Serialize(listmodel.Union(listown, ec));  //合并數據


                    listLeUpdate.Add(own);
                }
                else
                {
                    listLeInsert.Add(model);
                }
            }
            CurrentRepository.UpdateAll(listLeUpdate);
            CurrentRepository.InsertAll(listLeInsert);
            CurrentRepository.Save();
        }


tblLims_Ana_LE_Import_Common 為數據庫中存數據的表

 

Union() 方法中用到的自定義比較類:

 

復制代碼代碼如下:


/// <summary> 
    /// 自定義比較類 
    /// </summary> 
    public class EntityComparer : IEqualityComparer<Dictionary<string, string>>
    {
        public bool Equals(Dictionary<string, string> x, Dictionary<string, string> y)
        {
            if (ReferenceEquals(x, y)) return true;

 

            if (ReferenceEquals(x, null) || ReferenceEquals(y, null))
                return false;

            return x["name"] == y["name"];  //如果名稱相同就不追加
        }

        public int GetHashCode(Dictionary<string, string> obj)
        {
            if (ReferenceEquals(obj, null)) return 0;
            int hashName = obj["name"] == null ? 0 : obj["name"].GetHashCode();
            int hashCode = obj["name"] == null ? 0 : obj["name"].GetHashCode();
            return hashName ^ hashCode;
        }
    }

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产一级免费av | 久久99精品久久久久久青青日本 | 亚洲视频在线网 | 国产精品亚洲一区二区三区久久 | 九九色精品 | 国产精品成人一区二区三区电影毛片 | 噜噜在线视频 | 久久久久国产成人免费精品免费 | 2021国产精品 | 欧美jizzhd极品欧美 | 亚洲午夜视频在线 | 成人一级视频在线观看 | 亚洲福利在线免费观看 | 成人小视频免费在线观看 | 国产亚洲精品久久久久婷婷瑜伽 | 在线1区| 国产99视频精品免视看9 | 国产在线观看91精品 | 国产一级不卡毛片 | 欧美日韩亚洲精品一区二区三区 | 国产91久久精品一区二区 | 成人性视频免费网站下载软件 | 久久久久女人精品毛片九一 | 日本在线视频免费 | 91精品视频网址 | 暖暖免费观看高清完整版电影 | 久久视讯 | 国产精品久久999 | 亚洲精品a在线观看 | 一级片在线免费观看 | 成人 精品 | 一区二区三区精品国产 | 免费看一区二区三区 | 久久精品com| 成人啪啪18免费网站 | 亚洲国产资源 | 欧美一级高潮 | 国产精品视频免费在线观看 | 久久久久中文字幕 | 成人在线观看一区二区 | 欧美日韩国产一区二区三区在线观看 |