博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ASP.Net MVC OA项目笔记<三>
阅读量:7237 次
发布时间:2019-06-29

本文共 3210 字,大约阅读时间需要 10 分钟。

1.1.1 业务层和数据层之间加一个数据会话层,封装所有数据操作类实例的创建(工厂类)

         工厂类是负责对象的创建

         作用:将BLL和DAL解耦了,提供一个数据访问的统一访问点  

         数据会话层DBSession

         业务层BLL通过数据会话层DBSession调用数据操作类的实例

1.1.2 CZBK.ItcastOA.DALFactory添加一个类 DBSession

         并引用Model,IDAL,DAL

1.1.3 创建一个工厂类

 

1.1.4 一个业务可能涉及到对多张表的操作,这时候我希望只连一次数据库完成对多张表的操作,写一个保存的方法

         先创建一个EF上下文操作类

1.1.5 要操作数据库连接对象,就必须引入EF,同之前一样,通过创建一个实体数据模型来引入EF

1.1.6 DBSession 提供一个工厂解耦,并提供一个保存的方法

///     /// 1.数据会话层:就是一个工厂类,负责完成所有数据操作类实例的创建,然后业务层通过数据会话层来获取要操作数据类的实例,    /// 所以数据会话层将业务层和数据层解耦。    /// 2.在数据会话层中提供一个方法:完成所有数据的保存。    ///     public class DBSession    {        OAEntities Db = new OAEntities();        private IUserInfoDal _UserInfoDal;        public IUserInfoDal UserInfoDal        {            get            {                if(_UserInfoDal==null)                {                    _UserInfoDal=new UserInfoDal();                }                return _UserInfoDal;            }            set            {                _UserInfoDal = value;            }        }        ///         /// 一个业务中经常涉及到对多张表的操作,我们希望连接一次数据库,完成对这张表数据的操作,提高性能         /// 工作单元模式        ///         /// 
public bool SaveChanges() { return Db.SaveChanges() > 0; } }

1.2.1 数据层DAL的BaseDal中,SaveChanges就不要了,都注释掉

         在数据层中进行操作都只是在EF打上相应的标记,执行SaveChages时才进行数据库保存,不注释的话没调一次方法就得连一次数据库

         工作单元模式:连一次数据库,把多条数据一次性保存回数据库

public class BaseDal
where T : class, new() { OAEntities Db = new OAEntities(); ///
/// 新增 /// ///
///
public T AddEntity(T entity) { Db.Set
().Add(entity);//DbSet
//Db.SaveChanges(); return entity; } ///
/// 删除 /// ///
///
public bool DeleteEntity(T entity) { //追加到ef上,打上删除标记,再保存 Db.Entry
(entity).State = System.Data.Entity.EntityState.Deleted; //return Db.SaveChanges() > 0; return true; } ///
/// 更新 /// ///
///
public bool EditEntity(T entity) { //追加到ef上,打上编辑标记,再保存 Db.Entry
(entity).State = System.Data.Entity.EntityState.Modified; //return Db.SaveChanges() > 0; return true; } ///
/// 查询过滤 /// ///
///
public IQueryable
LoadEntities(Expression
> whereLambda) { return Db.Set
().Where(whereLambda); } ///
/// 分页 /// ///
///
页码 ///
每页数量 ///
总数 ///
过滤条件 ///
排序条件 ///
///
public IQueryable
PageLoadEntities
(int pageIndex, int pageSize, out int totalCount, Expression
> whereLambda, Expression
> orderbyLambda, bool isAsc) { var temp = Db.Set
().Where(whereLambda); totalCount = temp.Count(); if (isAsc)//正序 { //列:pageIndex=3,pageSize=15 //正序排列后,跳过第3页前的数据(前2页*15),剩下的只读取15条 temp = temp.OrderBy
(orderbyLambda).Skip
((pageIndex - 1) * pageSize).Take
(pageSize); } else//倒序 { temp = temp.OrderByDescending
(orderbyLambda).Skip
((pageIndex - 1) * pageSize).Take
(pageSize); } return temp; } }

 

转载于:https://www.cnblogs.com/VSMinos/p/9758382.html

你可能感兴趣的文章
idea 中解决maven 包冲突的问题(maven helper)
查看>>
Minikube体验
查看>>
[十八]JavaIO之FileReader 和 FileWriter
查看>>
Python 中parse.quote类似JavaScript encodeURI() 函数
查看>>
关于http和rpc的区别(segmentfault上的回答)
查看>>
JIRA简介
查看>>
C语言里的位域
查看>>
XX类库 不包含适合于入口点的静态“Main”方法
查看>>
海量存储(转)
查看>>
图形设备接口的起源
查看>>
区域实现Android实现图片的裁剪(不调用系统功能)
查看>>
Windows下配置Nginx代理Django
查看>>
解决 Delphi XE5 写Android程序的No resource identifier found for attribute... 错误【转】
查看>>
51. N-Queens
查看>>
Linux如何查看JDK的安装路径
查看>>
SyteLine实现字段过滤
查看>>
vs2015启动网站调试提示 HTTP 错误 403.14 - Forbidden Web 服务器被配置为不列出此目录的内容。 解决方法...
查看>>
【LeetCode OJ】Longest Substring Without Repeating Characters
查看>>
利用Ant脚本生成war包的详细步骤
查看>>
Oracle分页查询语句
查看>>