TinyDal is a lightweight and minimal abstraction over ORMs. It provides a convenient abstraction over it.
Usage:
// for some use cases see also the tests project in the solution
private class MyEntity : MultiTenantEntity
{
public override long TenantId { get; set; }
public override bool IsDeleted { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public override long Id { get; set; }
public string Name { get; set; }
}
private class MyEntityRepository : EFBaseRepository<MyEntity>
{
public MyEntityRepository (long? tenantId, DbContext context) : base(tenantId, context)
{
}
public void QueryRaw(string sql) //custom raw query here if you want
{
base.ExecuteRaw(sql);
}
}
private class MyDataContext : EFBaseDataContext
{
private DbSet<MyEntity> MyEntities { get; set; }
public MyEntityRepository MyEntityRepository { get; private set; }
public MyDataContext(DbContextOptions options,
long? tenantId,
IsolationLevel isolationLevel = IsolationLevel.ReadCommitted)
: base(options, tenantId, isolationLevel)
{
this.MyEntityRepository = new MyEntityRepository(tenantId, this);
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<MyEntity>().ToTable("MyEntities");
}
}
//
// Main
//
private MyDataContext BuildDataContext(string connectionString)
{
var optionsBuilder = new DbContextOptionsBuilder<MyDataContext>();
optionsBuilder.UseSqlServer(connectionString);
return new MyDataContext(optionsBuilder.Options, 1);
}
string connectionString = @"Server=(localdb)\dev;Database=TinyDalTestDb;Integrated security=True;";
using (var dataContext = this.BuildDataContext(connectionString))
{
dataContext.MyEntityRepository.Insert(new MyEntity
{
//Id = 1,
Name = "Name"
});
dataContext.Save();
dataContext.Commit();
}
Some implemented features:
- Lightweight abstraction
- Soft-delete management
- Multi-tenant entity management
For the feature usage see the test project.
- NHibernate implementation
- Dapper implementation
MIT
THIS SOFTWARE IS PROVIDED "AS IS" BY THE OWNER AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OWNER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.