Skip to content

Latest commit

 

History

History
56 lines (54 loc) · 1.46 KB

README.md

File metadata and controls

56 lines (54 loc) · 1.46 KB

dapper-query-builder

Build query for Dapper

How to use

public class PostgresQueryBuilder<TEntity> : QueryBuilder<TEntity> where TEntity : class
    {
        public PostgresQueryBuilder() : base(new DbConfig(DbConfig.DbType.Postgres))
        {
            EnableSnakeCase = true;
        }
    }

Entity Structure

[Table("Master", Schema = "public")]
public class MasterEntity
{
    [Key]
    public Guid MasterId { get; set; }
    public string Name { get; set; }
    public bool Status { get; set; }
    public long CreatedOn { get; set; }
    public Guid CreatedBy { get; set; }
    public long ModifiedOn { get; set; }
    public Guid ModifiedBy { get; set; }
}

Insert

var queryBuilder = new PostgresQueryBuilder<MasterEntity>();
var entity = new MasterEntity();
entity.MasterId = Guid.NewGuid();
entity.CreatedBy = userInfo.UserId;
entity.CreatedOn = CurrentTime;
entity.ModifiedBy = userInfo.UserId;
entity.ModifiedOn = CurrentTime;
entity.Status = true;
queryBuilder._entity = entity;
var result = queryBuilder.Build(BuildType.Insert);

Update

var queryBuilder = new PostgresQueryBuilder<MasterEntity>();
 queryBuilder.Set(m => m.Name, "Partha")
 .Set(m => m.ModifiedBy,"Partha")
 .Set(m => m.ModifiedOn, DateTime.UtcNow);
 var result = queryBuilder.Build(BuildType.Update);

Delete

var queryBuilder = new PostgresQueryBuilder<MasterEntity>();
 queryBuilder.Where(m => m.MasterId=='id');
 var result = queryBuilder.Build(BuildType.Delete);