C# FreeSql使用,基于Sqlite的DB Frist和Code First测试
using System;
using FreeSql.DataAnnotations;
using Xunit;
public class FreeSqlTest {
class Discuss {
[Column(IsPrimary = true)]
public int Id { get; set; }
public string Title { get; set; }
public int CategoryId { get; set; }
[Navigate(nameof(CategoryId))]
public Category Category { get; set; }
}
class Category {
[Column(IsPrimary = true)]
public int Id { get; set; }
public string Name { get; set; }
[Navigate(nameof(Discuss.CategoryId))]
public System.Collections.Generic.List<Discuss> Discuts { get; set; }
}
[Fact]
public void EnsureCreated() {
var fsql = new FreeSql.FreeSqlBuilder()
.UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=document.db;Pooling=true;Max Pool Size=10")
.UseAutoSyncStructure(true) //自动同步实体结构到数据库
.Build();
fsql.CodeFirst.Entity<Discuss>(eb => {
eb.ToTable("discuss");
eb.HasKey(e => e.Id);
eb.Property(e => e.Title).HasColumnType("text");
eb.HasIndex(e => e.Title);
eb.HasNavigation(
e => e.Category,
navigationBuilder => {
navigationBuilder.ToTable("category");
navigationBuilder.HasKey(e => e.Id);
navigationBuilder.Property(e => e.Name);
}
);
});
var discutCount = fsql.Select<Discuss>().Count();
Assert.Equal(0, discutCount);
}
}
这段代码演示了如何使用FreeSql来进行基于Sqlite的Code First操作。首先,我们创建了一个FreeSql实例,指定了数据库类型和连接字符串。然后,我们通过CodeFirst.Entity
方法定义了一个实体映射,包括表名、主键、列类型和索引。最后,我们通过Select
方法查询Discuss表中的记录数,并使用xUnit的Assert来验证记录数是否为0。这个例子简单地展示了如何使用FreeSql进行数据库结构的创建和管理。
评论已关闭