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;
}
}
您可能感兴趣的文章:
- Queryable.Union 方法实现json格式的字符串合并的具体实例
- Queryable.Union 方法实现json格式的字符串合并
- JS实现的一个query字符串转Json格式数据的方法
- JS实现的一个query字符串转Json格式数据的方法
- C#实现将类的内容写成JSON格式字符串的方法
- python中json格式数据输出的简单实现方法
- JS解析json数据并将json字符串转化为数组的实现方法
- 把json格式的字符串转换成javascript对象或数组的方法总结
- js中json对象和字符串的理解及相互转化操作实现方法
- ajax实例:如何使用json+ajax的方法实现类似前端特效tab切换效果
- asp.net中C#获取字符串中汉字的个数的具体实现方法
- C#实现将字符串转换成日期格式的方法
- @ResponseBody注解时返回字符串被转成json格式会多出双引号的解决方法
- Java Web程序实现返回JSON字符串的方法总结
- JS JSON对象转为字符串的简单实现方法
- 关于new Function使用以及将json格式字符串转化为json对象方法介绍
- 实例解析Json反序列化之ObjectMapper(自定义实现反序列化方法)
- Java 实例 - 压栈出栈的方法实现字符串反转
- Json字符串转换为JS对象的高效方法实例
- android解析php输出的json格式字符串实例