1、简介
PetaPoco是一个小型、快速、单文件的微型ORM(Object Relational Mapper)框架,可在.NET和Mono环境运行。
https://github.com/CollaboratingPlatypus/PetaPoco
2、特点
PetaPoco 是一个用于 .NET 的小型且快速的微型 ORM
与Dapper一样,它很快,因为它使用动态方法生成 (MSIL) 将列值分配给属性
像Massive一样,它现在也支持动态 Expandos
与ActiveRecord一样,它支持对象和数据库表之间的密切关系
与SubSonic一样,它支持使用 T4 模板生成 poco 类(仅限 V5)
与Massive一样,它以单个文件的形式提供,您可以轻松地将其添加到任何项目或编译。(仅限 V5)
3、功能
很小,绝对没有依赖!
异步或同步,选择权在您。(又名异步)(V6)
与严格未修饰的 POCO 或归属的几乎 POCO 一起使用。
易于配置,包括开箱即用的流畅配置。
插入/删除/更新/保存和 IsNew 的辅助方法
分页请求会自动计算出总记录数并获取特定页面。
简单的交易支持。
更好的参数替换支持,包括从对象属性中获取命名参数。
通过使用 DynamicMethod 生成消除 Linq 和快速属性分配来获得出色的性能。
查询语言是好的 ole SQL。
包括一个低摩擦的 SQL 构建器类,使编写内联 SQL变得更加容易。
包括 T4 模板以自动为您生成 POCO 类。(V5)
用于记录异常、安装值转换器和将列映射到没有属性的属性的挂钩。
适用于 SQL Server、SQL Server CE、MS Access、SQLite、MySQL、MariaDB、Firebird 和 PostgreSQL。(Oracle 支持但没有集成测试)。
在 Net Standard 2.0、.NET 4.0/4.5+ 或 Mono 2.8 及更高版本下工作。
有Xunit单元测试。
已支持 DBs 集成测试。
开源(MIT 许可证或 Apache 2.0)
4、简单例子
添加
[Fact]public void Insert(){// Create the personvar person = new Person { Id = Guid.NewGuid(), Name = "PetaPoco", Dob = new DateTime(2011, 1, 1), Age = (DateTime.Now.Year - 2011), Height = 242 };// Tell PetaPoco to insert itvar id = DB.Insert(person);// Obviously the ID returned will be the same as the one we setid.ShouldBe(person.Id);// Get a clone/copy from the DBvar clone = DB.Single<Person>(id);// See, they're are the sameclone.ShouldBe(person);// But, they're not not reference equals as PetaPoco doesn't cache because it's a MircoORM.person.Equals(clone).ShouldBeFalse();}
更新
// Create and insert the personvar person = new Person { Id = Guid.NewGuid(), Name = "PetaPoco", Dob = new DateTime(2011, 1, 1), Age = (DateTime.Now.Year - 2011), Height = 242 };var id = DB.Insert(person);// Update a few properties of the personperson.Age = 70;person.Name = "The PetaPoco";// Tell PetaPoco to update the DBDB.Update(person);// Get a clone/copy from the DBvar clone = DB.Single<Person>(id);// See, the person has been updatedclone.Id.ShouldBe(person.Id);clone.Dob.ShouldBe(person.Dob);clone.Height.ShouldBe(person.Height);clone.Age.ShouldBe(person.Age);clone.Name.ShouldBe(person.Name);
删除
// Create the personvar person = new Person { Id = Guid.NewGuid(), Name = "PetaPoco", Dob = new DateTime(2011, 1, 1), Age = (DateTime.Now.Year - 2011), Height = 242 };// Tell PetaPoco to insert itDB.Insert(person);// Obviously, we find only 1 matching person in the dbvar count = DB.ExecuteScalar<int>("SELECT COUNT([Id]) FROM [People] WHERE [Id] = @Id", new { person.Id });count.ShouldBe(1);// Tell PetaPoco to delete itDB.Delete(person);// Obviously, we should now have none in the dbcount = DB.ExecuteScalar<int>("SELECT COUNT([Id]) FROM [People] WHERE [Id] = @0", person.Id);count.ShouldBe(0);
查询
var inmemorylist = db.Fetch<article>("SELECT * FROM Articles")
foreach (var a in inmemorylist)
{ Console.WriteLine($"{a.Id} - {a.Title}");
}Console.WriteLine($"Count: {inmemorylist.Count}");
foreach (var a in db.Query<article>("SELECT * FROM Articles"))
{ Console.WriteLine($"{a.Id} - {a.Title}");
}
更多方法见
https://github.com/CollaboratingPlatypus/PetaPoco/wiki/