新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
asp.net core中怎么定义数据访问层,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都创新互联公司是一家专业提供淮滨企业网站建设,专注与网站设计、网站制作、H5网站设计、小程序制作等业务。10年已为淮滨众多企业、政府机构等服务。创新互联专业网站建设公司优惠进行中。
通常情况下,一个项目的数据实体中字段并不是完全没有规律可寻。通常情况下,必须有一个主键。有些时候,会要求在数据表中增加上次修改时间和创建时间,以及创建人和修改人的主键。
所以,我们可以创建一个泛型父类,来帮我们定义这些公共字段:
using System;
namespace Data.Infrastructure
{
public class BaseEntity
{
public T Id { get; set; }
public string ModifyUserId { get; set; }
public DateTime? ModifyTime { get; set; }
public string CreatorId { get; set; }
public DateTime? CreateTime { get; set; }
}
}
看上述代码里,命名空间并不在Data里,而是在Data.Infrastructure里。这个命名空间 Infrastructure 用来存放一些项目的架构类或者接口,里面还会其他的类。
那么,给这个类补充一些可能有用的方法:
public void Create(object userId)
{
CreatorId = userId.ToString();
CreateTime = DateTime.Now;
}
public void Create(object userId, DateTime createTime)
{
CreatorId = userId.ToString();
CreateTime = createTime;
}
public void Modify(object userId)
{
ModifyUserId = userId.ToString();
ModifyTime = DateTime.Now;
}
public void Modify(object userId, DateTime modifyTime)
{
ModifyUserId = userId.ToString();
ModifyTime = modifyTime;
}
这里用来保存用户ID的字段,我都用了字符串做保存,是借用字符串类型保存数据时能容纳更多的数据类型。
在正常开发中,一个完整的数据操作接口会有很多分类,但是很多时候我们需要分开增删改和查询这两种操作。对于数据库而言,视图和有些数据表都是不被允许改变的,这时候就需要我们只对调用方开放查询接口,而不开放修改接口。
所以,在Domain下应该有以下两个接口:
using System;
using System.Collections.Generic;
using System.Linq.Expressions;
namespace Domain.Infrastructure
{
///
/// 修改接口
///
///
public interface IModifyRepository
{
///
/// 插入数据
///
///
///
T Insert(T entity);
///
/// 插入数据
///
///
void Insert(params T[] entities);
///
/// 插入数据
///
///
void Insert(IEnumerable entities);
///
/// 保存已提交的修改
///
///
void Update(T entity);
///
/// 保存已提交的修改
///
///
void Update(params T[] entities);
///
/// 更新数据
///
///
///
void Update(Expression> predicate, Expression> updator);
///
/// 删除
///
///
void Delete(T entity);
///
/// 删除数据
///
///
void Delete(params T[] entities);
///
/// 根据条件删除数据
///
///
void Delete(Expression> predicate);
///
/// 删除主键对应的数据
///
///
void DeleteByKey(object key);
///
/// 删除主键对应的数据
///
///
void DeleteByKeys(params object[] keys);
}
}
上述是更新接口,那么我们回过头来写查询接口,查询接口的方法有很多。我们先创建一个接口文件:
using System;
using System.Linq.Expressions;
namespace Domain.Infrastructure
{
///
/// 查询接口
///
///
public interface ISearchRepository
{
}
}
一个查询接口应该包括以下方法:
获取单个数据
///
/// 根据主键获取数据
///
///
///
T Get(object key);
///
/// 查询
///
///
///
T Get(Expression> predicate);
统计数量:
///
/// 返回数据库中的数据条目
///
///
int Count();
///
/// 返回数据库中的数据条目,类型为Long
///
///
long LongCount();
///
/// 返回符合条件的数据数目
///
///
///
int Count(Expression> predicate);
///
/// 返回长整形的符合条件的数目
///
///
///
long LongCount(Expression> predicate);
存在性判断
///
/// 是否存在满足条件的数据
///
///
///
bool IsExists(Expression> predicate);
查询
//
/// 返回数据库中所有记录
///
///
List Search();
///
/// 返回所有符合条件的数据
///
///
///
List Search(Expression> predicate);
///
/// 返回一个延迟查询的对象
///
///
IEnumerable Query();
///
/// 返回一个延迟查询的对象,并预设了一个查询条件
///
///
///
IEnumerable Query(Expression> predicate);
排序
///
/// 排序查询,默认升序
///
///
///
///
///
List Search(Expression> predicate, Expression> order);
///
/// 排序查找,指定是否降序排列
///
///
///
///
///
///
List Search(Expression> predicate, Expression> order, bool isDesc);
分页
实际上分页的接口定义模型需要两个类的辅助,如果没有这两个类,接口的定义会变得十分复杂,不利于代码的可读性:
using System;
using System.Collections.Generic;
using System.Linq.Expressions;
namespace Data.Infrastructure
{
///
/// 分页条件模型
///
///
public class PageCondition
{
///
/// 查询条件
///
///
public Expression> Predicate { get; set; }
///
/// 排序字段
///
///
public string OrderProperty { get; set; }
///
/// 升序排序或者降序排序,升序为 asc或者空,降序为desc
///
///
public string Sort{get;set;}
///
/// 每页最大数据容量
///
///
public int PerpageSize { get; set; }
///
/// 当前页
///
///
public int CurrentPage { get; set; }
}
///
/// 分页结果
///
///
public class PageModel
{
///
/// 数据
///
///
public List Items { get; set; }
///
/// 当前页码
///
///
public int CurrentPage { get; set; }
///
/// 每页最大数据容量
///
///
public int PerpageSize { get; set; }
///
/// 查询数据总数
///
///
public long TotalCount { get; set; }
///
/// 总页码
///
///
public int TotalPages { get; set; }
}
}
这是两个辅助类,可以简单看一下如果这些参数不进行封装直接传给方法,可以预见方法的参数列表会特别长,这对于可读性和可维护性来说简直就是灾难。我曾经接手过一个项目的维护,上一位开发者在一个方法写了近15个参数,而且还有大量的可选参数,嗯,十分头疼。所以,我不建议大家这样写,一个方法参数超过4个我建议还是封装一下。
那么,看一看方法的声明:
///
/// 根据分页参数设置,进行分页查询
///
///
///
PageModel Search(PageCondition condition);
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。