ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(4)之业务仓储工厂
在创建业务层之前,我们先来熟悉一下业务仓储工厂Bobo.Repository.dll程序集,后续的业务操作,我们都将通过这个程序集中的方法传递数据库操作,其介于数据库操作与业务层之间,详情可前往《MVC仓储类Repository》查看。
1、RepositoryFactory<T> where T : new() 类:业务仓储工厂,负责创建继承至IRepository接口的类的对象实例
(1)方法 IRepository<T> Repository() 获取当前泛型指定的类型实例
(2)属性 IRepository<T> Factory 获取当前泛型指定的类型实例
2、Repository<T> 类:实现IRepository<T>接口的类,提供了业务操作的基础操作方法,主要负责与数据层交互,业务逻辑类需继承此类
| 类型 | 成员名称 | 参数说明 | 详细解析 |
|---|---|---|---|
| 方法 | DbTransaction BeginTrans() | 事务开始 | |
| 方法 | void Commit() | 提交事务 | |
| 方法 | void Rollback() | 回滚事务 | |
| 方法 | void Close() | 关闭数据库连接,非特殊情况无需手动调用 | |
| 方法 | int ExecuteBySql(StringBuilder strSql) | strSql:需要执行的sql语句,StringBuilder对象 | 执行SQL语句 |
| 方法 | int ExecuteBySql(StringBuilder strSql, DbTransaction isOpenTrans) | strSql:需要执行的sql语句,StringBuilder对象;isOpenTrans:事务对象(通过DbTransaction BeginTrans()创建) | 执行SQL语句,并封装到一个事务中 |
| 方法 | int ExecuteBySql(StringBuilder strSql, DbParameter[] parameters) | strSql:需要执行的sql语句,StringBuilder对象;parameters:sql语句对应参数(如“@param”,“值”) | 执行SQL语句 |
| 方法 | int ExecuteBySql(StringBuilder strSql, DbParameter[] parameters, DbTransaction isOpenTrans) | strSql:需要执行的sql语句,StringBuilder对象;parameters:sql语句对应参数(如“@param”,“值”);isOpenTrans:事务对象 | 执行SQL语句 |
| 方法 | int ExecuteByProc(string procName) | procName:存储过程名称,指数据库里存在的存储过程 | 执行存储过程 |
| 方法 | int ExecuteByProc(string procName, DbTransaction isOpenTrans) | procName:存储过程名称;isOpenTrans:事务对象 | 执行存储过程,带事务 |
| 方法 | int ExecuteByProc(string procName, DbParameter[] parameters) | procName:存储过程名称;parameters:参数对象数组 | 执行存储过程,带参数数组 |
| 方法 | int ExecuteByProc(string procName, DbParameter[] parameters, DbTransaction isOpenTrans) | procName:存储过程名称;parameters:参数对象数组;isOpenTrans:事务对象 | 执行存储过程,带参数数组和事务 |
| 方法 | int Insert(T entity) | entity:泛型类型实体对象 | 插入数据 |
| 方法 | int Insert(T entity, DbTransaction isOpenTrans) | entity:泛型类型实体对象;isOpenTrans:事务对象 | 插入数据 |
| 方法 | int Insert(List<T> entity) | entity:实体对象集合 | 批量插入数据 |
| 方法 | int Insert(List<T> entity, DbTransaction isOpenTrans) | entity:实体对象集合;isOpenTrans:事务对象 | 批量插入数据,带事务 |
| 方法 | int Update(T entity) | entity:要修改的实体对象 | 修改数据 |
| 方法 | int Update(T entity, DbTransaction isOpenTrans) | entity:要修改的实体对象;isOpenTrans:事务对象 | 修改数据,带事务 |
| 方法 | int Update(string propertyName, string propertyValue) | propertyName:预修改对象列名;propertyValue:预修改对象列值 | 修改数据 |
| 方法 | int Update(string propertyName, string propertyValue, DbTransaction isOpenTrans) | propertyName:预修改对象列名;propertyValue:预修改对象列值;isOpenTrans:事务对象 | 修改数据,带事务 |
| 方法 | int Update(List<T> entity) | entity:实体对象集合 | 批量修改数据 |
| 方法 | int Update(List<T> entity, DbTransaction isOpenTrans) | entity:实体对象集合;isOpenTrans:事务对象 | 批量修改数据,带事务 |
| 方法 | int Delete(T entity) | entity:实体对象 | 删除数据 |
| 方法 | int Delete(T entity, DbTransaction isOpenTrans) | entity:实体对象;isOpenTrans:事务对象 | 删除数据 |
| 方法 | int Delete(object propertyValue) | propertyValue:主键值 | 删除数据,根据主键值删除 |
| 方法 | int Delete(object propertyValue, DbTransaction isOpenTrans) | propertyValue:主键值;isOpenTrans:事务对象 | 删除数据,根据主键值删除,带事务 |
| 方法 | int Delete(string propertyName, string propertyValue) | propertyName:列名(属性名);propertyValue:列值(属性值) | 删除数据,根据属性名和属性值删除,可能是批量删除 |
| 方法 | int Delete(string propertyName, string propertyValue, DbTransaction isOpenTrans) | propertyName:列名(属性名);propertyValue:列值(属性值);isOpenTrans:事务对象 | 删除数据,根据属性名和属性值删除,可能是批量删除,带事务 |
| 方法 | int Delete(string tableName, Hashtable ht) | tableName:删除的表名;ht:条件键值对(根据ht生成where语句) | 删除数据 |
| 方法 | int Delete(string tableName, Hashtable ht, DbTransaction isOpenTrans) | tableName:删除的表名;ht:条件键值对(根据ht生成where语句);isOpenTrans:事务对象 | 删除数据 |
| 方法 | int Delete(object[] propertyValue) | propertyValue:主键值数组 | 根据主键数组批量删除 |
| 方法 | int Delete(object[] propertyValue, DbTransaction isOpenTrans) | propertyValue:主键值数组;isOpenTrans:事务对象 | 根据主键数组批量删除,带事务 |
| 方法 | int Delete(string propertyName, object[] propertyValue) | propertyName:属性名(列名);propertyValue:字段值:数组1,2,3,4,5,6..... | 批量删除数据 |
| 方法 | int Delete(string propertyName, object[] propertyValue, DbTransaction isOpenTrans) | propertyName:属性名(列名);propertyValue:字段值:数组1,2,3,4,5,6.....;isOpenTrans:事务对象 | 批量删除数据 |
| 方法 | List<T> FindListTop(int Top) | Top:显示条数 | 查询数据列表、返回List |
| 方法 | List<T> FindListTop(int Top, string propertyName, string propertyValue) | Top:显示条数;propertyName:实体属性名称;propertyValue:字段值; | 查询数据列表、返回List |
| 方法 | List<T> FindListTop(int Top, string WhereSql) | Top:显示条数;WhereSql:条件(注:条件需要以AND开头,例如“AND filed=‘一个值’”) | 查询数据列表、返回List |
| 方法 | List<T> FindListTop(int Top, string WhereSql, DbParameter[] parameters) | Top:显示条数;WhereSql:条件(AND开头);parameters:条件中的参数 | 查询数据列表、返回List |
| 方法 | List<T> FindList() | 查询所有数据列表、返回List | |
| 方法 | List<T> FindList(string propertyName, string propertyValue) | propertyName:实体属性名称;propertyValue:字段值 | 查询数据列表、返回List |
| 方法 | List<T> FindList(string WhereSql) | WhereSql:条件(AND开头); | 查询数据列表、返回List |
| 方法 | List<T> FindList(string WhereSql, DbParameter[] parameters) | WhereSql:条件(AND开头);parameters:where条件中的参数值数组 | 查询数据列表、返回List |
| 方法 | List<T> FindListBySql(string strSql) | strSql:完整SQL语句 | 查询数据列表、返回List |
| 方法 | List<T> FindListBySql(string strSql, DbParameter[] parameters) | strSql:完整SQL语句;parameters:sql语句中的参数值 | 查询数据列表、返回List |
| 方法 | List<T> FindListPage(ref JqGridParam jqgridparam) | jqgridparam:ref参数,用于存放分页参数 | 查询数据列表、返回List |
| 方法 | List<T> FindListPage(string WhereSql, ref JqGridParam jqgridparam) | WhereSql:条件(AND开头);jqgridparam:ref参数,用于存放分页参数 | 查询数据列表、返回List |
| 方法 | List<T> FindListPage(string WhereSql, DbParameter[] parameters, ref JqGridParam jqgridparam) | WhereSql:条件(AND开头);parameters:sql语句中的参数;jqgridparam:ref参数,用于存放分页参数 | 查询数据列表、返回List |
| 方法 | List<T> FindListPageBySql(string strSql, ref JqGridParam jqgridparam) | strSql:完整sql语句;jqgridparam:ref参数,用于存放分页参数 | 查询数据列表、返回List |
| 方法 | List<T> FindListPageBySql(string strSql, DbParameter[] parameters, ref JqGridParam jqgridparam) | strSql:完整sql语句;parameters:sql语句中定义的参数;jqgridparam:ref参数,用于存放分页参数 | 查询数据列表、返回List |
| 方法 | DataTable FindTableTop(int Top) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTableTop(int Top, string WhereSql) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTableTop(int Top, string WhereSql, DbParameter[] parameters) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTable() | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTable(string WhereSql) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTable(string WhereSql, DbParameter[] parameters) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTableBySql(string strSql) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTableBySql(string strSql, DbParameter[] parameters) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTablePage(ref JqGridParam jqgridparam) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTablePage(string WhereSql, ref JqGridParam jqgridparam) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTablePage(string WhereSql, DbParameter[] parameters, ref JqGridParam jqgridparam) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTablePageBySql(string strSql, ref JqGridParam jqgridparam) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTablePageBySql(string strSql, DbParameter[] parameters, ref JqGridParam jqgridparam) | 查询数据列表、返回 DataTable | |
| 方法 | DataTable FindTableByProc(string procName) | procName:数据库中存在的存储过程名称 | 查询数据列表、返回 DataTable |
| 方法 | DataTable FindTableByProc(string procName, DbParameter[] parameters) | procName:数据库中存在的存储过程名称;parameters:存储过程中使用的参数; | 查询数据列表、返回 DataTable |
| 方法 | DataSet FindDataSetBySql(string strSql) | 查询数据列表、返回DataSet | |
| 方法 | DataSet FindDataSetBySql(string strSql, DbParameter[] parameters) | 查询数据列表、返回DataSet | |
| 方法 | DataSet FindDataSetByProc(string procName) | procName:存储过程名称 | 查询数据列表、返回DataSet |
| 方法 | DataSet FindDataSetByProc(string procName, DbParameter[] parameters) | 查询数据列表、返回DataSet | |
| 方法 | T FindEntity(object propertyValue) | propertyValue:主键值 | 查询对象、返回实体 |
| 方法 | T FindEntity(string propertyName, object propertyValue) | propertyName:实体属性名称;propertyValue:字段值 | 查询对象、返回实体 |
| 方法 | T FindEntityByWhere(string WhereSql) | WhereSql:条件(AND开头) | 查询对象、返回实体 |
| 方法 | T FindEntityByWhere(string WhereSql, DbParameter[] parameters) | WhereSql:条件(AND开头);parameters:WhereSql中用到的参数 | 查询对象、返回实体 |
| 方法 | T FindEntityBySql(string strSql) | strSql:完整SQL语句 | 查询对象、返回实体 |
| 方法 | T FindEntityBySql(string strSql, DbParameter[] parameters) | strSql:完整SQL语句;parameters;strSql参数中用到的参数 | 查询对象、返回实体 |
| 方法 | int FindCount() | 查询数据、返回条数 | |
| 方法 | int FindCount(string propertyName, string propertyValue) | 查询数据、返回条数 | |
| 方法 | int FindCount(string WhereSql) | 查询数据、返回条数 | |
| 方法 | int FindCount(string WhereSql, DbParameter[] parameters) | 查询数据、返回条数 | |
| 方法 | int FindCountBySql(string strSql) | 查询数据、返回条数 | |
| 方法 | int FindCountBySql(string strSql, DbParameter[] parameters) | 查询数据、返回条数 | |
| 方法 | object FindMax<T>(string propertyName) where T : new() | propertyName:列名 | 查询数据、返回最大数 |
| 方法 | object FindMax(string propertyName, string WhereSql) | 查询数据、返回最大数 | |
| 方法 | object FindMax(string propertyName, string WhereSql, DbParameter[] parameters) | 查询数据、返回最大数 | |
| 方法 | object FindMaxBySql(string strSql) | 查询数据、返回最大数 | |
| 方法 | object FindMaxBySql(string strSql, DbParameter[] parameters) | 查询数据、返回最大数 |
ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(4)之业务仓储工厂的更多相关文章
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(13)之会员登录注册
源码下载地址:http://www.yealuo.com/Sccnn/Detail?KeyValue=c891ffae-7441-4afb-9a75-c5fe000e3d1c 会员中心,是我们与用户交 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(1)之数据库设计
本文主要讲解本项目网站所应用到的知识点,及数据库的相关设计: 一.知识点 (1)本项目主要采取ASP.NET MVC的编程模式,相信你已经了解到了MVC的具体含义是什么,这里不再赘述,有不了解的朋友, ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(16)之轻博客
源码下载地址:http://www.yealuo.com/Sccnn/Detail?KeyValue=c891ffae-7441-4afb-9a75-c5fe000e3d1c 项目到上面一步其实已经算 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(15)之前台网站页面
源码下载地址:http://www.yealuo.com/Sccnn/Detail?KeyValue=c891ffae-7441-4afb-9a75-c5fe000e3d1c 本项目主要是一个素材的分 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(14)之会员中心管理
源码下载地址:http://www.yealuo.com/Sccnn/Detail?KeyValue=c891ffae-7441-4afb-9a75-c5fe000e3d1c 会员中心,主要包含了会员 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(9)之系统登录
前面我们已经做好了一个文章管理功能模块,接下来,我们回头来做登录窗口,登录不仅涉及到登录验证还涉及到登录日志还有缓存时长等. 对于缓存的相关设置,我们已经写好封装在Bobo.Utilities.dll ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(7)之扩展基类和区域创建以及文本编辑配置
一.扩展基类和区域创建 (1)在应用之前,我们先在表现层创建一个公共的系统扩展文件来(SystemExtension)存放我们需要延伸和扩展的方法类. 在常规的项目系统操作中,我们都需要用到增删查改的 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(2)之创建项目
我们在创建项目的时候一定要遵循层次和命名的原则,同时也要有统一的规范,无论是多人项目还是单人项目,能够让人看着一目了然并赏析悦目,做一个有追求的程序员. 例如IA.WebApp是视图控制器层(表现层) ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(8)之文章管理
到这一步,我们整个项目的核心搭建已经算是完成了,接下来就是我们业务功能的实际应用,也就是表现层的设计和实现,如果你是一个项目负责人,到这一步,接下来的工作就可以交给下面的兄弟去完成了,在这里我们用文章 ...
随机推荐
- 【python小随笔】单例模式设计(易懂版)
1:单例模式原理 大道理:希望在系统中某个对象只能存在一个,单例模式是最好的解决方案,单例模式是一种常见的软件设置模式,在它的核心结构中只包含一个被称为单例类的特殊类,通过单例模式可以保证系统中的一个 ...
- github中markdown语言的使用规则
开始使用github就接触了markdown,确实如它的宗旨所言"易读易写",语法简洁明了,功能比纯文本更强,是一种非常适用于网络的书写语言.并且一大优点是兼容HTML,只要不在m ...
- MYSQL中LIMIT用法_后台分页
LIMIT是MySQL内置函数,其作用是用于限制查询结果的条数. 1)其语法格式如下: LIMIT[位置偏移量,]行数 其中,中括号里面的参数是可选参数,位置偏移量是指MySQL查询分析器要从哪一行开 ...
- windows.open window.location.href的用法和区别
window.location.href 只能在当前页面打开,不能用新窗口打开 windows.open("URL","窗口名称","窗口外观设定& ...
- 【风马一族_mysql】mysql基本指令
船停在港湾是很安全的,但那不是造船的目的! 用户 创建用户 mysql>grant 权限(select,insert,update,delete) on 数据库.数据表 to 用户名@电脑 ...
- 新一代视频AI服务 —— 阿里云智能视觉重磅发布
3月27日下午,第51期阿里云产品发布会-智能视觉产品隆重发布,本次产品发布会首次面向全网用户深入的解读了智能视觉的前世今生. 行业背景 随着人工智能的技术不断成熟,AI逐渐在各行业内落地.在新零售领 ...
- 使用iPhone为Apple Watch制作动画
(原文:Make Animations for APPLE WATCH Using iPhone 作者:Andy Drizen 译者:xiaoying) 无论要做一个像hamburger button ...
- H5+ 重写在线升级版本比较代码
重写h5+在线升级版本比较代码 hello h5+版本在线升级提供了如下的版本比较方法,逻辑比较繁琐,相关判断多余,非常不宜读. 先判断新旧版本有无, 接着分割为数组比较数组项大小,而且还只取了前四项 ...
- 容器化ICT融合初体验
[编者的话]本次将分享的容器化ICT融合平台是一种面向未来ICT系统的新型云计算PaaS平台,它基于容器这一轻量级的虚拟化技术以及自动化的"微服务"管理架构,能够有效支撑应用快速上 ...
- 一维数组的求平均成绩 Day06
package com.sxt.arraytest1; /* * 求班里学生的平均成绩,以及成绩的综合 输出每个同学的成绩 */ import java.util.Arrays; import jav ...