• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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(ListtblLims_Ana_LE_Import_Common> listLe)
            {
                var listLeInsert = new ListtblLims_Ana_LE_Import_Common>();
                var listLeUpdate = new ListtblLims_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.DeserializeListDictionarystring, string>>>(own.fldImportData);  //原数据
                        var listmodel = ser.DeserializeListDictionarystring, string>>>(model.fldImportData); //新数据
                        IEqualityComparerDictionarystring, 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 : IEqualityComparerDictionarystring, string>>
        {
            public bool Equals(Dictionarystring, string> x, Dictionarystring, 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(Dictionarystring, 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;
            }
        }

    您可能感兴趣的文章:
    • JS实现合并json对象的方法
    • JavaScript简单实现合并两个Json对象的方法示例
    • JavaScript实现JSON合并操作示例【递归深度合并】
    • js根据json数据中的某一个属性来给数据分组的方法
    • Javascript中JSON数据分组优化实践及JS操作JSON总结
    • JS遍历JSON数组及获取JSON数组长度操作示例【测试可用】
    • JavaScript实现构造json数组的方法分析
    • JS实现键值对遍历json数组功能示例
    • JavaScript数组,JSON对象实现动态添加、修改、删除功能示例
    • js实现json数组分组合并操作示例
    上一篇:Json返回时间的格式中出现乱码问题的两种解决方案
    下一篇:silverlight用webclient大文件上传的实例代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Queryable.Union 方法实现json格式的字符串合并的具体实例 Queryable.Union,方法,实现,