首页
/ FreeSql 使用 Fluent API 配置实体映射详解

FreeSql 使用 Fluent API 配置实体映射详解

2025-06-15 10:58:42作者:柏廷章Berta

什么是 Fluent API

Fluent API 是一种通过代码方式配置实体与数据库表映射关系的方法。相比特性注解方式,Fluent API 提供了更灵活、更强大的配置能力,可以在不修改实体类的情况下完成复杂的映射配置。

基本配置方法

在 FreeSql 中,我们可以通过实现 IEntityTypeConfiguration<T> 接口来为实体类配置映射关系。下面是一个完整的配置示例:

public class SongConfiguration : IEntityTypeConfiguration<Song>
{
    public void Configure(EfCoreTableFluent<Song> eb)
    {
        // 配置表名
        eb.ToTable("tb_song");
        
        // 配置主键
        eb.HasKey(e => e.Id);
        
        // 配置字段
        eb.Property(e => e.Title)
            .HasColumnName("title")  // 自定义列名
            .HasComment("歌曲标题")   // 添加注释
            .IsRequired();           // 设置为必填
            
        eb.Property(e => e.Url)
            .HasMaxLength(500)       // 设置最大长度
            .IsRequired();
            
        eb.Property(e => e.CreateTime)
            .HasDefaultValueSql("CURRENT_TIMESTAMP"); // 设置默认值
            
        eb.Property(e => e.RowVersion)
            .IsRowVersion();        // 设置为行版本
    }
}

常用配置项详解

1. 表名配置

eb.ToTable("tb_song"); // 指定表名

2. 主键配置

eb.HasKey(e => e.Id); // 指定主键

3. 字段配置

字段配置是最常用的部分,可以配置以下内容:

  • 列名HasColumnName("column_name")
  • 注释HasComment("字段说明")
  • 是否必填IsRequired()IsRequired(false)
  • 最大长度HasMaxLength(100)
  • 默认值HasDefaultValue("默认值")HasDefaultValueSql("SQL表达式")
  • 忽略字段Ignore() 不映射到数据库

4. 索引配置

eb.HasIndex(e => e.Title); // 单字段索引
eb.HasIndex("idx_title_url", e => new { e.Title, e.Url }); // 复合索引

5. 导航属性配置

eb.HasOne(e => e.Album)   // 一对一关系
    .WithMany()           // 对应多端
    .HasForeignKey(e => e.AlbumId); // 外键

命名转换策略

FreeSql 支持全局的命名转换策略,可以在构建 FreeSql 对象时指定:

var fsql = new FreeSqlBuilder()
    .UseConnectionString(DataType.MySql, connectionString)
    .UseNameConvert(NameConvertType.PascalCaseToUnderscoreWithLower) // 驼峰转下划线
    .Build();

这样配置后,类似 RowVersion 的属性会自动映射为 row_version 列名,无需单独配置。

应用配置

配置完成后,需要在 CodeFirst 迁移时应用配置:

fsql.CodeFirst.ApplyConfiguration(new SongConfiguration());

最佳实践

  1. 集中管理配置:为每个实体创建单独的配置类,便于维护
  2. 合理使用注释:通过 ///<summary>HasComment() 双重注释,既方便代码阅读又能在数据库中看到字段说明
  3. 保持一致性:团队内统一命名风格和配置方式
  4. 优先使用 Fluent API:相比特性注解,Fluent API 更灵活且不污染实体类

通过以上方式,可以充分利用 FreeSql 的 Fluent API 功能,实现灵活、可维护的实体-数据库映射配置。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
148
1.95 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
931
555
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
980
395
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
65
515