FreeSql中弱类型CRUD操作Update时IgnoreColumns的使用注意事项
在使用FreeSql进行数据库操作时,开发者可能会遇到弱类型CRUD操作中Update方法忽略字段(IgnoreColumns)无效的情况。本文将深入分析这一问题,并给出正确的解决方案。
问题现象
当开发者尝试使用弱类型方式进行数据更新时,可能会编写类似以下代码:
var res = await DB.SqlServer.Update<object>()
.AsType(Type.GetType($"Models." + TableName))
.SetDto(ndata)
.WhereDynamic(type.GetProperty("Id").GetValue(ndata))
.IgnoreColumns(new[] { "Id" })
.ExecuteUpdatedAsync();
期望通过IgnoreColumns方法忽略ID字段的更新,但实际执行后发现该配置并未生效,ID字段仍然被包含在更新语句中。
原因分析
FreeSql提供了两种不同的更新模式,它们对字段忽略的处理方式有所不同:
-
SetSource + IgnoreColumns/UpdateColumns组合模式:这是FreeSql推荐的标准用法,在这种模式下,字段忽略功能可以正常工作。
-
SetDto模式:这是一种批量设置模式,其设计初衷是快速将DTO对象映射到数据库实体,因此它有自己的字段处理逻辑,不会与IgnoreColumns直接配合使用。
解决方案
要正确实现字段忽略功能,应采用FreeSql推荐的标准用法:
var res = await DB.SqlServer.Update<object>()
.AsType(Type.GetType($"Models." + TableName))
.SetSource(ndata) // 使用SetSource而非SetDto
.WhereDynamic(type.GetProperty("Id").GetValue(ndata))
.IgnoreColumns(new[] { "Id" }) // 现在IgnoreColumns会生效
.ExecuteUpdatedAsync();
最佳实践建议
-
明确操作模式:在使用FreeSql进行更新操作前,应先确定使用哪种模式。如果需要精细控制更新的字段,应优先考虑SetSource模式。
-
理解方法语义:
SetSource:设置要更新的数据源,适合需要精确控制更新字段的场景SetDto:快速批量设置DTO数据,适合简单场景IgnoreColumns:明确指定要忽略的字段UpdateColumns:明确指定要更新的字段
-
类型安全考虑:虽然FreeSql支持弱类型操作,但在可能的情况下,尽量使用强类型方式,可以获得更好的编译时检查和IDE支持。
-
性能考量:对于大批量更新操作,明确指定更新的字段(无论是通过IgnoreColumns还是UpdateColumns)可以减少不必要的数据传输,提高性能。
总结
FreeSql提供了灵活的CRUD操作方式,但不同方法间的配合使用需要遵循一定的规则。理解SetSource和SetDto两种模式的区别,是正确使用字段忽略功能的关键。在实际开发中,建议开发者根据具体需求选择合适的模式,并参考官方文档了解各方法的详细行为,以避免类似问题的发生。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00