前言

尝试过 ado.net、dapper、ef,以及Repository仓储,甚至自己还写过生成器工具,以便做常规CRUD操作。

它们日常操作不方便之处:

  • 每次使用前需要声明,再操作;

  • 很多人一个实体类,对应一个操作类(或DAL、DbContext、Repository);

BaseEntity 是一种极简单的 CodeFirst 开发方式,特别对单表或多表CRUD,利用继承节省了每个实体类的重复属性(创建时间、ID等字段),软件删除等功能,进行 crud 操作时不必时常考虑仓储的使用;

本文介绍 BaseEntity 一种极简约的 CRUD 操作方法。

功能特点

  • 自动迁移实体结构(CodeFirst),到数据库;

  • 直接操作实体的方法,进行 CRUD 操作;

  • 简化用户定义实体类型,省去主键、常用字段的配置(如CreateTime、UpdateTime);

  • 实现单表、多表查询的软删除逻辑;

声明

示范项目:https://github.com/2881099/FreeSql/tree/master/Examples/base_entity

参考 BaseEntity.cs 源码(约100行),拷贝项目中使用,然后添加 nuget 引用包:

dotnet add package FreeSql.Repository

dotnet add package FreeSql.Provider.Sqlite

1、定义一个主键 int 并且自增的实体类型,BaseEntity TKey 指定为 int/long 时,会认为主键是自增;

public class UserGroup : BaseEntity<UserGroup, int>
{
public string GroupName { get; set; }
}

如果不想主键是自增键,可以重写属性:

public class UserGroup : BaseEntity<UserGroup, int>
{
[Column(IsIdentity = false)]
public override int Id { get; set; }
public string GroupName { get; set; }
}

有关更多实体的特性配置,请参考资料:https://github.com/2881099/FreeSql/wiki/实体特性

2、定义一个主键 Guid 的实体类型,保存数据时会自动产生有序不重复的 Guid 值(不用自己指定 Guid.NewGuid());

public class User : BaseEntity<UserGroup, Guid>
{
public string UserName { get; set; }
}

3、定义多主键的实体类型,可以在 static 构造函数中重写字段名;

public class User2 : BaseEntity<User2, Guid, int>
{
static User2()
{
User2.Orm.CodeFirst.ConfigEntity<User2>(t =>
{
t.Property(a => a.PkId1).Name("UserId");
t.Property(a => a.PkId2).Name("Index");
});
} public string Username { get; set; }
}

CRUD 使用

//添加
var item = new UserGroup { GroupName = "组一" };
item.Insert(); //更新
item.GroupName = "组二";
item.Update(); //添加或更新
item.Save(); //软删除
item.Delete(); //恢复软删除
item.Restore(); //根据主键获取对象
var item = UserGroup.Find(1); //查询数据
var items = UserGroup.Where(a => a.Id > 10).ToList();

实体类型.Select 是一个查询对象,使用方法和 FreeSql.ISelect 一样;

支持多表查询时,软删除条件会附加在每个表中;

有关更多查询方法,请参考资料:https://github.com/2881099/FreeSql/wiki/查询

最新文章

  1. git添加GitHub远程库
  2. Java的String中的subString()方法
  3. python 路径
  4. Linux之mount命令详解
  5. BZOJ1049: [HAOI2006]数字序列
  6. VR开发中性能问题—OculusWaitForGPU
  7. ovs处理openflow消息的流程
  8. shell 踩坑记
  9. SpringBoot入坑-持久化操作
  10. C++ 值传递、指针传递、引用传递详解
  11. 关于height,line-height导致的样式混乱的问题
  12. Oracle 存储过程或函数传入的数值参数number
  13. 通用程序返回结果类 ApplicationResult.cs
  14. 数据持久化—真机上的Plist写入
  15. flask入门小方法
  16. 加州靡情第一至七季/全集Californication迅雷下载
  17. Nginx隐藏主机信息,proxy_hide_header 与fastcgi_hide_header
  18. sql or语法
  19. 网络图片嗅探工具driftnet
  20. java webservice maven spring Class Not Found Exception解决

热门文章

  1. 什么水平算精通C++ Builder?
  2. Qt 5.6.0 动态编译(VS2013 x86 target xp openssl icu webkit)
  3. 使用Func&lt;T1, T2, TResult&gt; 委托返回匿名对象
  4. PHP调用语音合成接口
  5. HTML连载16-颜色控制属性2&amp;标签选择器
  6. SpringBoot整合日志框架LogBack
  7. Spring Boot:整合Spring Data JPA
  8. Storm 学习之路(二)—— Storm核心概念详解
  9. string类总结第一部分函数介绍
  10. SpringBoot 缓存注解 与EhCache的使用