我们已经根据设计好的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中使用

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

数据访问层DAL的更多相关文章

  1. 数据访问层DAL(数据库访问抽象类DataProvider)

    晒晒数据访问层DAL,看看你的项目数据访问层使用的是什么形式,数据访问性能比较 采用什么样的数据访问形式是软件编码很重要的一个环节,良好的数据访问形式不仅能够提搞代码的执行效率,协作能力,更重要的是对 ...

  2. 1.1 DAL数据访问层

    分布式(Distributed)数据访问层(Data Access Layer),简称DAL,是利用MySQL Proxy.Memcached.集群等技术优点而构建的一个架构系统.主要目的是解决高并发 ...

  3. 加载的DAL数据访问层的类型

    using System; using System.Collections; using System.Reflection; using CSFrameworkV4_5.Core; using C ...

  4. 使用JDBC构建简单的数据访问层

    本教程的目的是使用Java编写的分离的层去访问数据库中的表,这一层通常称为数据访问层(DAL) 使用DAL的最大好处是通过直接使用一些类似insert()和find()的方法简化了数据库的访问操作,而 ...

  5. 企业级应用架构(三)三层架构之数据访问层的改进以及测试DOM的发布

    在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层能够支持一切数据访问技术,如Ado.n ...

  6. 数据访问层的改进以及测试DOM的发布

    数据访问层的改进以及测试DOM的发布 在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层 ...

  7. ClownFish:比手写代码还快的通用数据访问层

    http://www.cnblogs.com/fish-li/archive/2012/07/17/ClownFish.html 阅读目录 开始 ClownFish是什么? 比手写代码还快的执行速度 ...

  8. 使用Ninject+Moq在单元测试中抽象数据访问层

    一.测试方法的业务逻辑时,通常都需要从数据库读取测试数据,但是每次初始化数据库数据都很麻烦,也会影响到其它业务对数据的访问,怎样抽象数据访问层呢?就是用Moq去模拟数据访问的逻辑     二.步骤如下 ...

  9. 【Hades】ades是一个开源库,基于JPA和Spring构建,通过减少开发工作量显著的改进了数据访问层的实现

    几乎每个应用系统都需要通过访问数据来完成工作.要想使用领域设计方法,你就需要为实体类定义和构建资源库来实现领域对象的持久化.目前开发人员经常使用JPA来实现持久化库.JPA让持久化变得非常容易,但是仍 ...

随机推荐

  1. 要成为一个 Java 架构师得学习哪些知识?

    作者:zhuqz链接:https://www.zhihu.com/question/29031276/answer/54631312来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请 ...

  2. 单机版 RedisUtils({基本操作封装工具类})【三】

    <!--集成的RedisJAR--> <!--引入jedis需的jar包--> <dependency> <groupId>redis.clients& ...

  3. Linux 基本命令总结

    0.平时自己用的命令 在跑一些程序,例如deep learning的时候,总是希望查看一下cpu.gpu.内存的使用率. (1)cpu.内存情况:使用top命令: (2)查看gpu:使用 nvidia ...

  4. runtime error 的原因

    1.  数组访问越界 2.  分母为 0 3.   括号 做题时偶然发现的! (详见 UVA 10158 War) 代码中出现了这种东西 else if( arefriends(x,y==-1)  ) ...

  5. Linux-tcpdump command

    简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具. tcpdump可以将网络中传送的数据包的 ...

  6. codeforces 598C C. Nearest vectors(极角排序)

    题目链接: C. Nearest vectors time limit per test 2 seconds memory limit per test 256 megabytes input sta ...

  7. 9th

    2017-2018-2 20179212<网络攻防实践>第9周作业 视频学习 KaliSecurity压力测试工具 压力测试通过确定一个系统的瓶颈或者不能接受的性能点,来获得系统能够提供的 ...

  8. Linux CentOS安装Azure Cli工具

    vim /etc/yum.repos.d/epel.repo [epel] name=epel baseurl=http://mirrors.sohu.com/fedora-epel/6/$basea ...

  9. MySQL on Azure高可用性设计 DRBD - Corosync - Pacemaker - CRM (二)

    在上一篇文章中描述了MySQL HA on Azured 设计思路,本篇文章中将描述具体的部署,每个组件的安装和配置. 整体的设计架构如下: 下面将是所有组件的安装配置过程,所有的虚拟机是CentOS ...

  10. 纯js+html+css实现模拟时钟

    前几天没事写的个模拟时钟,代码仅供小白参考,大神请自动绕过. <!DOCTYPE html> <html lang="en"> <head> & ...