The Wayback Machine - https://web.archive.org/web/20201101131213/https://github.com/dotnetcore/FreeSql
Skip to content
master
Go to file
Code

Files

Permalink
Failed to load latest commit information.

readme.md

🦄  FreeSql

nuget stats GitHub license

FreeSql 是功能强大的对象关系映射技术(O/RM),支�? .NETCore 2.1+ 或 .NETFramework 4.0+ 或 Xamarin。

  • 支�? CodeFirst �?移,哪怕使用 Access 数�?�库也支�?ï¼›
  • 支�? DbFirst 从数�?�库导入实体类,安装实体类生�?工具;
  • 支�? 深入的类型映射,比如pgsql的数组类型;
  • 支�? 丰富的表达�?函数,以�?��?�活的自定义解�?ï¼›
  • 支�? 导航属性一对多�?多对多贪婪加载,以�?�延时加载;
  • 支�? 读写分离�?分表分库�?过滤器�?�?观�?�?悲观�?ï¼›
  • 支�? MySql/SqlServer/PostgreSQL/Oracle/Sqlite/Firebird/达梦/人大金仓/神舟通用/Accessï¼›

📚  Documentation

《新人学习指引》 | 《Select》 | 《Update》 | 《Insert》 | 《Delete》
《表达�?函数》 | 《CodeFirst》 | 《DbFirst》 | 《过滤器》
《Repository》 | 《UnitOfWork》 | 《AOP》 | 《DbContext》
《读写分离》 | 《分表分库》 | 《黑科技》 | 《常�?问题》 | 更新日志

FreeSql �??供多�?使用习惯,请根�?�实际情况选择团队�?�适的一�?:

  • �?么FreeSql,原始用法;
  • �?么FreeSql.Repository,仓储+工作�?�元习惯;
  • �?么FreeSql.DbContext,有点�?efcore的使用习惯;
  • �?么FreeSql.BaseEntity,求简�?�使用这个;

示范项目

🚀  Quick start

dotnet add package FreeSql.Provider.Sqlite

static IFreeSql fsql = new FreeSql.FreeSqlBuilder()
  .UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=document.db")
  .UseAutoSyncStructure(true) //自动�?�步实体结构到数�?�库
  .Build(); //请务必定义�? Singleton �?�例模�?

class Song {
  [Column(IsIdentity = true)]
  public int Id { get; set; }
  public string Title { get; set; }
  public string Url { get; set; }
  public DateTime CreateTime { get; set; }
  
  public ICollection<Tag> Tags { get; set; }
}
class Song_tag {
  public int Song_id { get; set; }
  public Song Song { get; set; }
  
  public int Tag_id { get; set; }
  public Tag Tag { get; set; }
}
class Tag {
  [Column(IsIdentity = true)]
  public int Id { get; set; }
  public string Name { get; set; }
  
  public int? Parent_id { get; set; }
  public Tag Parent { get; set; }
  
  public ICollection<Song> Songs { get; set; }
  public ICollection<Tag> Tags { get; set; }
}

🔎  Query

//OneToOne�?ManyToOne
fsql.Select<Tag>().Where(a => a.Parent.Parent.Name == "粤语").ToList();

//OneToMany
fsql.Select<Tag>().IncludeMany(a => a.Tags, then => then.Where(sub => sub.Name == "xxx")).ToList();

//ManyToMany
fsql.Select<Song>()
  .IncludeMany(a => a.Tags, then => then.Where(sub => sub.Name == "xxx"))
  .Where(s => s.Tags.AsSelect().Any(t => t.Name == "国语"))
  .ToList();

//Other
fsql.Select<Xxx>()
  .Where(a => a.IsDelete == 0)
  .WhereIf(keyword != null, a => a.UserName.Contains(keyword))
  .WhereIf(role_id > 0, a => a.RoleId == role_id)
  .Where(a => a.Nodes.AsSelect().Any(t => t.Parent.Id == t.UserId))
  .Count(out var total)
  .Page(page, size)
  .OrderByDescending(a => a.Id)
  .ToList()

More..

fsql.Select<Song>().Where(a => new[] { 1, 2, 3 }.Contains(a.Id)).ToList();

fsql.Select<Song>().Where(a => a.CreateTime.Date == DateTime.Today).ToList();

fsql.Select<Song>().OrderBy(a => Guid.NewGuid()).Limit(10).ToList();

More..

�?  Repository

dotnet add package FreeSql.Repository

[Transactional]
public void Add() {
  var repo = ioc.GetService<BaseRepository<Tag>>();
  repo.DbContextOptions.EnableAddOrUpdateNavigateList = true;

  var item = new Tag {
    Name = "testaddsublist",
    Tags = new[] {
      new Tag { Name = "sub1" },
      new Tag { Name = "sub2" }
    }
  };
  repo.Insert(item);
}

�?�考:在 asp.net core 中使用 TransactionalAttribute + UnitOfWorkManager 实现多�?事务传播

💪  Performance

FreeSql Query & Dapper Query

Elapsed: 00:00:00.6733199; Query Entity Counts: 131072; ORM: Dapper

Elapsed: 00:00:00.4554230; Query Tuple Counts: 131072; ORM: Dapper

Elapsed: 00:00:00.6846146; Query Dynamic Counts: 131072; ORM: Dapper

Elapsed: 00:00:00.6818111; Query Entity Counts: 131072; ORM: FreeSql*

Elapsed: 00:00:00.6060042; Query Tuple Counts: 131072; ORM: FreeSql*

Elapsed: 00:00:00.4211323; Query ToList<Tuple> Counts: 131072; ORM: FreeSql*

Elapsed: 00:00:01.0236285; Query Dynamic Counts: 131072; ORM: FreeSql*

FreeSql ToList & Dapper Query

Elapsed: 00:00:00.6707125; ToList Entity Counts: 131072; ORM: FreeSql*

Elapsed: 00:00:00.6495301; Query Entity Counts: 131072; ORM: Dapper

More..

👯  Contributors

systemhejiyong�? LambertW�? mypeng1985�? stulzq�? movingsam�? ALer-R�? zouql�? 深圳|凉茶�? densen2014�? LiaoLiaoWuJu�? hd2y�? tky753�? feijie999�? constantine�? JohnZhou2020�? mafeng8

QQ群:4336577(已满)�?8578575(在线)�?52508226(在线)

💕  Donation

L*y 58元�?花花 88元�?麦兜很乖 50元�?网络�?�者 2000元�?John 99.99元�?alex 666元�?bacongao 36元�?无�?? 100元�?Eternity 188元�?无�?? 10元�?⌒.Helper~..oO 66元�?习惯与被习惯 100元�?无�?? 100元�?蔡易喋 88.88元�?中讯科技 1000元�?Good Good Work 24元�?炽焰 6.6元�?Nothing 100元�?兰州天擎赵 500元�?哈利路亚 300元�? 无�?? 100元�?蛰�? 99.99元�?TCYM 66.66元�?MOTA 5元�?LDZXG 30元�?Near 30元�?建爽 66元�?无�?? 200元�?LambertWu 100元�?无�?? 18.88元�?乌龙 50元

Thank you for your donation

About

🦄 .NET orm, Mysql orm, Postgresql orm, SqlServer orm, Oracle orm, Sqlite orm, Firebird orm, 达梦 orm, 人大金仓 orm, 神通 orm, MsAccess orm.

Topics

Resources

License

Languages

You can’t perform that action at this time.