EF Core怎么设置列的默认值 EF Core HasDefaultValue方法

发布时间 - 2025-12-29 00:00:00    点击率:
EF Core 的 HasDefaultValue 是让数据库在插入时自动填充未指定字段的默认值,通过迁移生成 CREATE TABLE 或 ALTER TABLE 语句将 DEFAULT 约束写入数据库;仅当 C# 实体未赋值该属性时生效,且只支持常量值,动态值需用 HasDefaultValueSql。

EF Core 设置列默认值,核心是让数据库在插入数据时自动填充未指定的字段。关键不在于 C# 层面赋值,而在于告诉数据库“这个列缺值时该填什么”。HasDefaultValue 就是做这件事的——它把默认值写进数据库表结构里,由数据库执行,不是 EF Core 在内存里帮你填。

什么时候 HasDefaultValue 生效

它只在数据库层面起作用,且只在以下两种迁移操作中生成对应 SQL:

  • 首次创建表:生成 CREATE TABLE ... MyColumn INT DEFAULT 100
  • 给已有表新增列:生成 ALTER TABLE ... ADD MyColumn INT DEFAULT 100,并自动为历史行补上默认值

怎么配置 HasDefaultValue

OnModelCreating 中用 Fluent API 配置:

modelBuilder.Entity()
  .Property(p => p.Price)
  .HasDefaultValue(0.0m);

支持常见类型:数值、字符串(如 "Unknown")、布尔(true)、日期(DateTime.Today)等。注意:传入的是常量值,不是表达式。

HasDefaultValue 和 HasDefaultValueSql 的区别

前者填固定值,后者填数据库运行时计算的值:

  • .HasDefaultValue(DateTime.UtcNow) → 写死一个时间点(迁移生成时的时间)
  • .HasDefaultValueSql("GETUTCDATE()") → 每次插入都取当前数据库时间

像自动时间戳、随机 GUID、序列号等动态场景,必须用 HasDefaultValueSql

插入数据时它怎么工作

EF Core 不会主动把默认值写进实体对象,也不在 SaveChanges 前自动赋值。它的行为很明确:

  • 你没给属性赋值 → EF Core 插入语句里不包含该列 → 数据库用 DEFAULT 填
  • 你显式赋了值(哪怕赋 null 或 0)→ EF Core 把这个值写进 INSERT → 覆盖数据库默认值

所以它真正起效的前提是:代码里“不碰”那个属性。

基本上就这些。不复杂但容易忽略:它管的是数据库,不是你的 C# 对象。


# 区别  # c#  # sql  # NULL  # 常量  # 字符串  # int  # Property  # 对象  # default  # table  # 数据库  # 默认值  # 的是  # 写进  # 只在  # 时计  # 首次  # 什么时候  # 已有  # 两种  # 帮你 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  奇安信“盘古石”团队突破 iOS 26.1 提权  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  JavaScript如何实现路由_前端路由原理是什么  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  Laravel如何创建自定义Facades?(详细步骤)  如何解决hover在ie6中的兼容性问题  佛山企业网站制作公司有哪些,沟通100网上服务官网?  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Laravel怎么调用外部API_Laravel Http Client客户端使用  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  如何在阿里云部署织梦网站?  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  bing浏览器学术搜索入口_bing学术文献检索地址  打造顶配客厅影院,这份100寸电视推荐名单请查收  如何实现javascript表单验证_正则表达式有哪些实用技巧  用v-html解决Vue.js渲染中html标签不被解析的问题  android nfc常用标签读取总结  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Laravel怎么为数据库表字段添加索引以优化查询  phpredis提高消息队列的实时性方法(推荐)  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  原生JS获取元素集合的子元素宽度实例  原生JS实现图片轮播切换效果  如何在万网利用已有域名快速建站?  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  如何在IIS中配置站点IP、端口及主机头?  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  如何在建站宝盒中设置产品搜索功能?  如何用y主机助手快速搭建网站?  详解jQuery停止动画——stop()方法的使用  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  Python文件操作最佳实践_稳定性说明【指导】  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何快速搭建FTP站点实现文件共享?  如何在万网自助建站平台快速创建网站?  nodejs redis 发布订阅机制封装实现方法及实例代码  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  黑客入侵网站服务器的常见手法有哪些?