一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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在线观看 | 四虎新网站 | 亚洲欧美日韩中文字幕网址 | 肉搏潘金莲三级18春 | 韩国漂亮美女三级在线观看 | 日本xxxxx69hd日本 | 国产成人久久久精品一区二区三区 | 香蕉久久久 | 黄动漫车车好快的车车a | 99r在线播放| 亚洲成人网导航 | 交换年轻夫妇HD中文字幕 | 亚洲国产成人在人网站天堂 | 亚洲精品久久久久AV无码 | 视频一区在线观看 | 白丝vk丨tk失禁 | 91制片厂免费观看 | 男男gaygays黑人| 青青青国产手机在线播放 | 香蕉久久久久久狠狠色 | 亚洲视频在线一区二区 | 91制片在线观看 | 69人成网站色www | 精品国产一区二区三区久久久狼 | 欧美色图亚洲天堂 | 99精品国产高清自在线看超 | 特级毛片免费视频观看 | 欧美午夜视频一区二区三区 | 午夜宅男网 | 欧美精品成人a多人在线观看 | a级aaaaaaaa毛片 | 青青草原免费在线视频 | 亚洲日本中文字幕在线2022 | 爸爸干女儿小说 | 麻豆小视频在线观看 | japanesqirl日本护士 | 幻女free性摘花第一次 | 5555kkkk香蕉在线观看 | 欧美性理论片在线观看片免费 | 99ri国产在线观看 | 国产日韩欧美在线一区二区三区 |