国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看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;
        }
    }

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲视频在线播放免费 | 国产成人精品一区二区三区视频 | 91精品国产综合久久久久久丝袜 | 91av电影网 | 午夜激情影院 | 亚洲免费a | 麻豆91视频 | 国产视频一区在线 | 国产在线观看二区 | 国产黄色播放 | 亚洲成人免费观看 | 亚洲经典一区 | 激情网页 | 精品国产一区二区三区小蝌蚪 | 91视视频在线观看入口直接观看 | 美国成人在线 | 国产色在线 | 久久久一区二区三区 | 亚洲精品一 | 久久久久久国产精品mv | 欧美操 | 国产999精品久久久影片官网 | 精品九九久久 | 国产精品一二 | 国产视频网 | 亚洲国产精品美女 | 激情毛片 | 国产欧美精品一区二区三区四区 | 久久99精品国产99久久6尤 | 欧美日韩成人在线观看 | 这里只有精品视频 | 日韩视频精品在线 | 成人在线免费观看视频 | 国产片免费看 | 狠狠的日| 午夜视频在线观看网站 | 欧美一级高清在线 | 久久精品无码一区二区三区 | 免费视频黄 | 亚洲资源站 | 成人免费影院 |