ef core修改指定的列数据

15 篇文章 0 订阅
/// <summary>
/// 异步修改集合,修改指定的列
/// </summary>
/// <param name="list">集合</param>
/// <param name="column">指定的列,参考 id,name。要修改的列名传入数组</param>
/// <returns></returns>
public async Task<int> UpdateListAsync(List<T> list, string[] column)
{
	foreach (var entity in list)
	{
		var entry = dbContext.Entry(entity);
		entry.State = EntityState.Modified;
		foreach (var item in column)
		{
			entry.Property(item).IsModified = true;
		}

		var listP=  entry.Properties.ToList();
		listP.RemoveAll(w=>w.Metadata.IsPrimaryKey());
		foreach (var item in listP)
		{
			string itemName= item.Metadata.Name;//字段名称
			//bool isKey= item.Metadata.IsPrimaryKey();
			//if (isKey)
			//{
			//    continue;
			//}
			if (column.Contains(itemName))
			{
				continue;
			}
			item.IsModified = false;
		}
	}
	//dbSet.UpdateRange(list);
	return await dbContext.SaveChangesAsync();
}



//调用参考:

/// <summary>
/// 批量删除
/// </summary>
/// <param name="ids"></param>
/// <returns></returns>
public async Task<int> DeleteByIdsAsync(string ids)
{          
	int count = 0;
	_unitOfWork.BeginTransaction();
	try
	{
		List<Media> list = new List<Media>();
		string[] arr = ids.Split(",");
		foreach (var id in arr)
		{
			list.Add(new Media() { Id = id, DataState = (short)EDataState.Delete });
		}
		count = await _mediaDal.UpdateListAsync(list, new string[] { "DataState" });
		_unitOfWork.CommitTransaction();
	}
	catch (Exception ex)
	{
		_unitOfWork.RollBackTransaction();
	}
	return count;
}



 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王焜棟琦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值