gpt4 book ai didi

c# - 在 SubmitChanges() 之前验证 Linq2Sql

转载 作者:太空狗 更新时间:2023-10-29 21:11:25 25 4
gpt4 key购买 nike

谁能告诉我是否/如何在 Linq2Sql 调用 SubmitChanges() 之前验证数据上下文中的更改。我遇到的情况是,我创建了一个上下文,执行多个操作并在其他处理任务中添加了许多插入,然后在提交失败时回滚。

我更愿意做的是在某些任务完成后调用某种“Validate()”,这样我就可以在提交整个作业之前处理它。

最佳答案

要获取数据上下文中的所有更改,您可以调用

ChangeSet changes = dataContext.GetChangeSet();

// An IList<Object>
changes.Deletes;
changes.Inserts;
changes.Updates;

我所拥有的是每个值对象都有一个验证方法。我使用属性来定义不同类型的验证。我手动执行此操作的原因是因为我在数据库和代码中有一个可能是 int 的数字,如果我保存年龄,则 1002 的值可能无效。所以我可以给出一个值的范围,等等。 .

如果您的每个值对象都继承自一个基础对象,那么迭代它们会更容易。假设您的基类有一个 Validate 方法。

我要指出的是,要使它起作用,您将不得不编辑生成的代码,或者推出您自己的值对象。由于我使用它们进行验证的方式,我通常会自己推出。

关于c# - 在 SubmitChanges() 之前验证 Linq2Sql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1212738/

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