gpt4 book ai didi

c# - 记录大数据字段 - 更新而不获取?

转载 作者:太空狗 更新时间:2023-10-29 22:19:15 28 4
gpt4 key购买 nike

我有一个表,其中图像为 varbinary(max),另一个数据(具有其他类型)更紧凑。我想更新另一个数据而不是图像。在循环(即所有记录)中,使用过滤器选择要更新的记录。我找到了各种解决方案,但所有解决方案都使用将整个记录提取到上下文中或将现有记录(即之前获取或创建的记录)附加到上下文中。说“之前某个时间获取或创建”是指包含所有字段的整个记录​​都已呈现 - 没有截断图像或其他“不必要的”字段。

有没有一种方法可以在不获取任何不必要的数据(例如 varbinary 图像)的情况下更新记录,而是通过 EF?也许只是获取任何没有所有字段但只包含我需要的字段的轻量级 POCO 对象?或者此类任务超出了 EF 的分配范围,我必须使用纯 SQL?

好吧,只是一个简单的例子:

数据库表:

create table Weed
(
Id int identity(1,1) not null,
Name nvarchar(100) not null,
Description nvarchar(max) null,
Image varbinary(max) null
)

EF 的 POCO

public partial class Weed
{
public Weed()
{}

public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public byte[] Image { get; set; }
}

我想更新描述而不获取整个杂草(尤其是图像字段),例如名称以“A”开头的杂草。

最佳答案

在 Entity Framework 中,如果您想在不首先获取实体的情况下进行更新,您应该能够像这样使用 DbContext.Entry 方法:

var model = new MyModel() { Id = id, OtherData = data };
using (var db = new MyEfContextName())
{
db.MyModels.Attach(model);
db.Entry(model).Property(x => x.OtherData).IsModified = true;
db.SaveChanges();
}

这应该告诉 EF 为您生成适当的 UPDATE 语句,而根本不必选择实体数据。

另一方面,如果您需要先执行简短的 SELECT 以检索 Id,例如,您可以在使用 Linq to Entities 进行选择时使用匿名类型:

var existingData = db.MyModels.Where(x => x.SomeParameter == someValue).Select(x => new { Id = x.Id, OtherData = x.OtherData }).SingleOrDefault();

这将生成一条 SELECT 语句,该语句仅选择您需要的数据并将其输出为匿名类型。

我应该指出,如果您正在执行复杂的查询或者您正在寻求效率,那么不要害怕使用 DbContext.Database.SqlQueryDbContext.Database.ExecuteSqlCommand。 Entity Framework 不会支持您可能想要做的所有事情,可以在需要时绕过它。

关于c# - 记录大数据字段 - 更新而不获取?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19276268/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com