zoukankan      html  css  js  c++  java
  • 数据访问层DAL

    我们已经根据设计好的pdm文件生成数据库,下面我们一起完成数据库访问层需要的工作

    在dal类库上点击右键,添加,新建项

    选择“ADO。NET实体数据模型”,会自动命名“Model1”

     选择“来自数据库的EF设计器”为什么不选择“Code First”呢?因为Oracle官方提供的EF,不支持Code First,所以有跨库需求的,还是选择这种最简单的方式吧。

     

     

     先测试一下连接,再确定

     

     下面会用你“数据库的名称+Entities”命名,不建议修改,下面你会用到

     

     如果你的电脑没有安装其他版本的EF,就不会出现下面的页面

     

     注意:不要选择“确定所生成对象名称的单复数形式(s)”,因为以后我们会配套代码生成器,对其他层的代码自动生成;

     

    完成后,生成如下的3个文件, 这3个文件都分别什么作用呢?

    好,我们通过3个进一步的问题回答,

    • 1.怎么将数据库由“Sys”变更为“HeXiao”呢?

    打开“App.Config”,来配置本类库的entity framework

     在解决方案中,双击打开“Model1.edmx”,然后Ctrl+A(全选),最后Delete,这样就删了所有的模型;

    在空白处点击右键,选择“从数据库更新模型”

     

     注意:这只完成了DAL类库的修改,还有系统的配置文件没有修改,将“App.config(只为DAL类库使用)”中内容拷贝到“Web.config(系统级别的配置文件)”

     为什么需要一致呢?因为config文件只给其所在应用程序使用,我们做的是bs架构的系统,外面访问的是展示层App,而在App层中的配置文件是Web.config,所以在App项目中是整个系统的所有配置文件,同理,下面的packages.config文件,也要保持一致,因为我们在DAL组件不需要再增加新的组件引用了,删除即可。

    • 2.packages.config的作用是什么?

    大家一定要清楚,作为常识

     

    下面我们新建一个文件夹“Framework”,存放本类库的公用代码,我们还会建一个文件夹,存放本类库的业务代码,且为后话。

    BaseRepository.cs是访问数据库表的基类

    using System.Linq;
    
    
    namespace Langben.DAL
    {
        public abstract class BaseRepository<T> where T : class
        {
            #region 字段
    
            /// <summary>
            /// 开始时间的标识
            /// </summary>
            public string Start_Time { get { return "Start_Time"; } }
            /// <summary>
            /// 结束时间的标识
            /// </summary>
            public string End_Time { get { return "End_Time"; } }
            /// <summary>
            /// 开始数值的标识
            /// </summary>
            public string Start_Int { get { return "Start_Int"; } }
            /// <summary>
            /// 结束数值的标识
            /// </summary>
            public string End_Int { get { return "End_Int"; } }        
            ///
            /// 精确字符串
            /// </summary>
            public string DDL_String { get { return "DDL_String"; } }
            /// <summary>
            /// 精确数字
            /// </summary>
            public string DDL_Int { get { return "DDL_Int"; } }
    
            #endregion
         
            /// <summary>
            /// 获取所有
            /// </summary>
            /// <param name="db">实体数据上下文</param>
            /// <returns>集合</returns>
            public virtual IQueryable<T> GetAll(SysEntities db)
            {
                return db.Set<T>().AsQueryable();
            }
            /// <summary>
            /// 创建
            /// </summary>
            /// <param name="db">实体数据上下文</param>
            /// <param name="entity">将要创建的对象</param>
            public virtual void Create(SysEntities db, T entity)
            {
                if (entity != null)
                {
                    db.Set<T>().Add(entity);
                }
            }
            /// <summary>
            /// 创建
            /// </summary>
            /// <param name="entity">一个对象</param>
            /// <returns>成功了几条数据</returns>
            public virtual int Create(T entity)
            {
                using (SysEntities db = new SysEntities())
                {
                    Create(db, entity);
                    return this.Save(db);
                }
            }
            /// <summary>
            /// 创建对象集合
            /// </summary>
            /// <param name="db">实体数据上下文</param>
            /// <param name="entitys">对象集合</param>
            public virtual void Create(SysEntities db, IQueryable<T> entitys)
            {
                foreach (var entity in entitys)
                {
                    this.Create(db, entity);
                }
            }
            /// <summary>
            /// 编辑一个对象
            /// </summary>
            /// <param name="db">实体数据</param>
            /// <param name="entity">将要编辑的一个对象</param>
            /// <param name="isAttach">是否附加到数据库上下文,如果对象是从数据库查询出来的,则为false</param>
            public virtual T Edit(SysEntities db, T entity, bool isAttach = true)
            {
                if (isAttach)
                    db.Set<T>().Attach(entity);
    
                db.Entry(entity).State = System.Data.Entity.EntityState.Modified;
                return entity;
            }
            /// <summary>
            /// 编辑对象集合
            /// </summary>
            /// <param name="db">实体数据</param>
            /// <param name="entitys">对象集合</param>
            public virtual void Edit(SysEntities db, IQueryable<T> entitys)
            {
                foreach (T entity in entitys)
                {
                    this.Edit(db, entity);
                }
            }
            /// <summary>
            /// 提交保存,持久化到数据库
            /// </summary>
            /// <param name="db">实体数据</param>
            /// <returns>受影响行数</returns>
            public int Save(SysEntities db)
            {
                return db.SaveChanges();
            }
    
        }
    }
    

    BaseViewRepository.cs是访问数据库视图的基类

    • 3.“Model1.edmx”整个文件有什么用?

    它将数据库映射成了我们可以在面向对象使中用的模型,包含了数据库访问用到的实体和数据库访问方法,我们约定:数据库访问用到的实体我们可以在其他层(BLL,IBLL,App)中使用,数据库访问方法只能在DAL中使用

    至此,数据库访问层搭建基本完成。可以只能

  • 相关阅读:
    【GStreamer开发】GStreamer基础教程14——常用的element
    【GStreamer开发】GStreamer基础教程12——流
    【GStreamer开发】GStreamer基础教程12——流
    【GStreamer开发】GStreamer基础教程11——调试工具
    【GStreamer开发】GStreamer基础教程11——调试工具
    【GStreamer开发】GStreamer基础教程10——GStreamer工具
    【GStreamer开发】GStreamer基础教程10——GStreamer工具
    【GStreamer开发】GStreamer基础教程09——收集媒体信息
    【GStreamer开发】GStreamer基础教程08——pipeline的快捷访问
    【GStreamer开发】GStreamer基础教程08——pipeline的快捷访问
  • 原文地址:https://www.cnblogs.com/angben/p/6792121.html
Copyright © 2011-2022 走看看