v1.4.0+ 已自动识别 EFCore 实体特性 Key/Required/NotMapped/Table/Column

主键(Primary Key)

class Topic {
[Column(IsPrimary = true)]
public int Id { get; set; }
}

约定:

  • 当没有指明主键时,命名为 id 的字段将成为主键;(不区分大小写)

  • 当主键是 Guid 类型时,插入时会自动创建(有序、不重复)的值,所以不需要自己赋值;(支持分布式)

自增(Identity)

class Topic {
[Column(IsIdentity = true)]
public int Id { get; set; }
}

约定:

  • 当没有指明主键时,标记自增的成员将成为主键;

唯一键(Unique Key)、索引(Index)

[Index("uk_phone", "phone", true)]
[Index("uk_group_index", "group,index", true)]
[Index("uk_group_index22", "group, index22 desc", true)]
class AddUniquesInfo
{
public Guid id { get; set; }
public string phone { get; set; } public string group { get; set; }
public int index { get; set; }
public string index22 { get; set; }
}

第三个参数 true 的时候是唯一键,false 的时候是普通索引。

数据库类型(DbType)

class Topic {
[Column(DbType = "varchar(128) NOT NULL")]
public string Title { get; set; }
}

可以在类型上指定 NOT NULL,也可以通过 [Column(IsNullable = false)] 设置;

0.12.8 版本增加了 [Column(StringLength = 128)] 针对字符串的长度设置;

0.9.12 版本增加了对 MaxLength 特性的解析,上面的 varchar(128) 可改写成:

class Topic {
[MaxLength(128)]
public string Title { get; set; }
}

当 string 长度 -1 时产生的映射如下:

MySql PostgreSQL SqlServer Oracle Sqlite MsAccess
text text varchar(max) nclob text longtext

注意:Oracle nclob 需要 v1.3.2+ 版本才支持,否则将映射 nvarchar2(4000)

服务器时间(ServerTime)

class Topic {

    [Column(ServerTime = DateTimeKind.Utc, CanUpdate = false)]
public DateTime CreateTime { get; set; } [Column(ServerTime = DateTimeKind.Utc)]
public DateTime UpdateTime { get; set; }
}

v0.12.4 使用数据库时间执行插入数据,注意:

1、一但设置了这个特性,插入的时候设置属性值是无效的;

2、插入实体执行成功后,实体的值还是 c# 时间;

v1.1 - ServerTime 特性,对 Update 方法时也能生效

其他参考:如果对时间精度要求不高,推荐下面的做法,先计算本地与服务器时间差距,再使用 Aop 统一处理:

var serverTime = fsql.Select<T>().Limit(1).First(a => DateTime.UtcNow);
var timeOffset = DateTime.UtcNow.Subtract(serverTime); //减去数据库时间 fsql.Aop.AuditValue += new EventHandler<Aop.AuditValueEventArgs>((_, e) =>
{
if (e.Column.Attribute.MapType.NullableTypeOrThis() == typeof(DateTime))
{
if (e.Value == null || (DateTime)e.Value == default(DateTime))
{
e.Value = DateTime.Now.Subtract(timeOffset); //使用本地时区保存
return;
}
}
});

可空(Nullable)

class Topic {
[Column(IsNullable = false)]
public string Title { get; set; }
}

在不指定 DbType、IsNullable 时,FreeSql 提供默认设定,如:

  • int -> not null(不可为空)
  • int? -> null(可空)

一般在使用 string 类型时,才需要手工指明是否可空(string 默认可空);

忽略(Ignore)

class Topic {
[Column(IsIgnore = true)]
public string Title { get; set; }
}

当实体有属性不需要映射的时候使用,内部自动忽略了对象的映射;

当实体内的属性不是可接受的类型时,可以不用指定该特定,如下不必要的指定:

class Topic {
[Column(IsIgnore = true)]
public Topic Parent { get; set; }
}

乐观锁(RowVersion)

class Topic {
public Guid id { get; set; }
public string Title { get; set; } [Column(IsVersion = true)]
public int Version { get; set; }
}

更新整个实体数据时,在并发情况下极容易造成旧数据将新的记录更新。

乐观锁的原理,是利用实体某字段,如:long version,更新前先查询数据,此时 version 为 1,更新时产生的 SQL 会附加 where version = 1,当修改失败时(即 Affrows == 0)抛出异常。

每个实体只支持一个乐观锁属性。

适用 SetSource 更新,无论使用什么方法更新 version 的值都会增加 1

自定义类型映射(MapType)

class EnumTestMap {
public Guid id { get; set; } [Column(MapType = typeof(string))]
public ToStringMapEnum enum_to_string { get; set; }
[Column(MapType = typeof(string))]
public ToStringMapEnum? enumnullable_to_string { get; set; } [Column(MapType = typeof(int))]
public ToStringMapEnum enum_to_int { get; set; }
[Column(MapType = typeof(int?))]
public ToStringMapEnum? enumnullable_to_int { get; set; } [Column(MapType = typeof(string))]
public BigInteger biginteger_to_string { get; set; }
[Column(MapType = typeof(string))]
public BigInteger? bigintegernullable_to_string { get; set; }
}
public enum ToStringMapEnum { 中国人, abc, 香港 }

BigInteger 也可以映射使用,但请注意:仅仅是 CURD 方便, Equals == 判断可以使用,无法实现 + - * / 等操作;

v0.9.15 版本还可以将值对象映射成 typeof(string),安装扩展包:

dotnet add package FreeSql.Extensions.JsonMap

fsql.UseJsonMap(); //开启功能

class TestConfig
{
public int clicks { get; set; }
public string title { get; set; }
}
[Table(Name = "sysconfig")]
public class S_SysConfig
{
[Column(IsPrimary = true)]
public string Name { get; set; } [JsonMap]
public TestConfig Config { get; set; }
}

字段位置(Position)

适用场景:当实体类继承时,CodeFirst创建表的字段顺序可能不是想要的,通过该特性可以设置顺序。

创建表时指定字段位置,如:[Column(Position = 1],可为负数即反方向位置;

可插入(CanInsert)、可更新(CanUpdate)

该字段是否可以插入或更新,默认值true,指定为false插入或更新时该字段会被忽略。

当指明了 InsertColumn/UpdateColumns 等方法时,该特性作用可能失效。例如 CanInsert = false 时,又指明了 InsertColumns 该属性,则仍然会插入。

自定义插入值(InsertValueSql)

执行 Insert 方法时使用此值,它的语法是 SQL。

注意:如果是 getdate() 这种请可考虑使用 ServerTime,因为它对数据库间作了适配。

class Type
{
[Column(InsertValueSql = "'xxx'")]
public string Name { get; set; }
} fsql.Insert(new Type()).ExecuteAffrows();
//INSERT INTO `type`(`Name`) VALUES('xxx')

名称

FreeSql 默认使用实体的类名,或属性名与数据库映射,也可以指定映射的名称;

指定实体的表名,指定 Name 后,实体类名变化不影响数据库对应的表。FreeSql尽量支持了对多数据库或schema支持,不防试试指定表名为:其他数据库.表名,不同数据库的指定方式有差异,这一点以后深入解答。

[Table(Name = "db2.tb_topic111")]
class Topic {
//...
}

注意:尽量不要使用带点的表名,只有 MySql/Sqlite 对此类表名支持 CodeFirst。但是它不影响 CRUD 功能,使用 [Table(Name = "`sys.config`")] 解决

指定实体的表名,修改为实体类名。指定数据库旧的表名,修改实体命名时,同时设置此参数为修改之前的值,CodeFirst才可以正确修改数据库表;否则将视为【创建新表】。

[Table(OldName = "Topic")]
class Topic2 {
//...
}

实体的属性也有相同的功能,[Column(Name = "xxx")]

禁用迁移

IFreeSql.CodeFirst.IsAutoSyncStructure 可设置全局【自动迁移结构】功能,也可通过 FreeSqlBuilder.UseAutoSyncStructure(true) 创建 IFreeSql 的时候设置功能。

当【实体类】对应的是数据库【视图】或者其他时,可通过 [Table(DisableSyncStructure = true)] 禁用指定的实体迁移操作。

[Table(DisableSyncStructure = true)]
class ModelDisableSyncStructure {
[Column(IsPrimary = false)]
public int pkid { get; set; }
}

备注

FreeSql CodeFirst 支持将 c# 代码内的注释,迁移至数据库的备注。先决条件:

1、实体类所在程序集,需要开启 xml 文档功能;

2、xml 文件必须与程序集同目录,且文件名:xxx.dll -> xxx.xml;

v1.5.0+ 版本增加了对 Description 特性的解析,优先级低于 c# 代码注释;

系列文章导航

最新文章

  1. POJ1753 Flip Game(bfs、枚举)
  2. MySQL的存储过程1
  3. iOS - Swift Swift 语言新特性
  4. winForm 程序开发界面参数传递
  5. thinkphp 整合 ucenter
  6. 水题(素数表)NYOJ素数距离
  7. REMOTE HOST IDENTIFICATION HAS CHANGED
  8. Js,alert出现乱码问题,赶紧记下来,额~~~
  9. ASP.net MVC 无法初始化 ASP.NET Simple Membership 数据库
  10. C#中抽象类与接口的区别
  11. 零开始:NetCore项目权限管理系统:定义基本接口和实现
  12. Hacking /dev/random: Pipe
  13. 使用 FFMPEG 命令为视频嵌入字幕
  14. AST的作用
  15. 获取resource下文件
  16. java基础知识总结--对象的克隆
  17. CentOS 6.5下PXE+Kickstart无人值守安装操作系统centos7.3
  18. Java两种核心机制
  19. CloudStack和OpenStack该如何选择(如果准备选择OpenStack,请做好hack的准备。CloudStack的底层功能已经做的很完善了,更适合商用)
  20. 超高清视频会议所需带宽分析---1M带宽应用720P是否可能?

热门文章

  1. [Spring cloud 一步步实现广告系统] 17. 根据流量类型查询广告
  2. 【POJ - 2387】Til the Cows Come Home(最短路径 Dijkstra算法)
  3. STL 队列
  4. MySQL-下载-安装-配置-多版本共存-设置密码-破解密码
  5. java后端开发面经 数据库相关
  6. 昂贵的聘礼 POJ - 1062
  7. 【资源共享】eBook分享大集合
  8. 【JS档案揭秘】第四集 关于this的讨论到此为止
  9. 曹工杂谈:一例简单的Jar包冲突解决示例
  10. 12款好用超赞的国外搜索资源网站 ,开发者们的标配,你都知道吗?不知道就OUT了