数据访问层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是访问数据库表的基类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 | 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中使用
至此,数据库访问层搭建基本完成。可以只能
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库