主页 > 知识库 > Queryable.Union 方法实现json格式的字符串合并的具体实例

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

热门标签:电销业务 电商新玩法 国美全国运营中心 科大讯飞语音识别系统 客户服务 网站排名优化 人工智能 百度AI接口

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数组分组合并操作示例

标签:厦门 攀枝花 南平 益阳 枣庄 拉萨 咸宁 POS机

巨人网络通讯声明:本文标题《Queryable.Union 方法实现json格式的字符串合并的具体实例》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266