基于.NET平台的分层架构实战(七)数据访问层的第一种实现:A
经过上面篇文章的介绍,整个系统的 框架 算是基本搭建完了,下面,我们要具体 实现 各个层次。关于 数据 访问 层的 实现 ,我准备讨论三种 实现 方式,这一篇文章讨论 第一 种:Access+动态生成SQL。 顾名思义,这种 实现 将使用Access作为后台 数据 库,而
经过上面篇文章的介绍,整个系统的框架算是基本搭建完了,下面,我们要具体实现各个层次。关于数据访问层的实现,我准备讨论三种实现方式,这一篇文章讨论第一种:Access+动态生成SQL。
顾名思义,这种实现将使用Access作为后台数据库,而操作方式也是最基本的使用SQL命令。
在具体编写实现代码之前,我们需要做一些准备工作:
第一步,我们要将Access数据库搭建完成,具体做法如下。
在Web工程下新建一个文件夹,命名为AccessData,并在其中新建一个mdb文件(即Access数据库文件),按照前面介绍过的数据库设计构架,将数据表及表间关系建好,这里不再赘述。
第二步,我们要进行一些配置。
打开Web工程下的Web.config文件,在其中的appSettings节点下,添加如下键值:
第一条为Access的连接字符串,第二条为Access数据库文件的路径,其中“~”表示网站根目录。
第三步,新建一个工程。
我们要新建一个工程AccessDAL,用来存放Access数据访问层的代码。
准备工作做完了,现在来实现具体的代码。
1.编写数据访问助手类
因为很多数据访问操作流程很相似,所以,这里将一些可复用的代码抽取出来,编写成助手类,以此减少代码量,提高代码复用性。
这个助手类放在AccessDAL下,叫AccessDALHelper,主要负责Access数据库的访问。它包括三个方法:
GetConnectionString:从配置文件中读取配置项,组合成连接字符串。
ExecuteSQLNonQuery:执行指定SQL语句,不返回任何值,一般用于Insert,Delete,Update命令。
ExecuteSQLDataReader:执行SQL语句返回查询结果,一般用于Select命令。
具体代码如下:
AccessDALHelper.cs:
AccessDALHelper
- 1using System;
- 2using System.Web;
- 3using System.Web.Caching;
- 4using System.Configuration;
- 5using System.Data;
- 6using System.Data.OleDb;
- 7using NGuestBook.Utility;
- 8
- 9namespace NGuestBook.AccessDAL
- 10{
- 11 /**////
- 12 /// Access数据库操作助手
- 13 ///
- 14 public sealed class AccessDALHelper
- 15 {
- 16 /**////
- 17 /// 读取Access数据库的连接字符串
- 18 /// 首先从缓存里读取,如果不存在则到配置文件中读取,并放入缓存
- 19 ///
- 20 ///
Access数据库的连接字符串 - 21 private static string GetConnectionString()
- 22 {
- 23 if (CacheAccess.GetFromCache("AccessConnectionString") != null)
- 24 {
- 25 return CacheAccess.GetFromCache("AccessConnectionString").ToString();
- 26 }
- 27 else
- 28 {
- 29 string dbPath = ConfigurationManager.AppSettings["AccessPath"];
- 30 string dbAbsolutePath = HttpContext.Current.Server.MapPath(dbPath);
- 31 string connectionString = ConfigurationManager.AppSettings["AccessConnectionString"];
- 32
- 33 CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
- 34 CacheAccess.SaveToCache("AccessConnectionString", connectionString.Replace("{DBPath}", dbAbsolutePath), fileDependency);
- 35
- 36 return connectionString.Replace("{DBPath}", dbAbsolutePath);
- 37 }
- 38 }
- 39
- 40 /**////
- 41 /// 执行SQL语句并且不返回任何值
- 42 ///
- 43 /// 所执行的SQL命令
- 44 /// 参数集合
- 45 public static void ExecuteSQLNonQuery(string SQLCommand,OleDbParameter[] parameters)
- 46 {
- 47 OleDbConnection connection = new OleDbConnection(GetConnectionString());
- 48 OleDbCommand command = new OleDbCommand(SQLCommand, connection);
- 49
- 50 for (int i = 0; i
- 51 {
- 52 command.Parameters.Add(parameters);
- 53 }
- 54
- 55 connection.Open();
- 56 command.ExecuteNonQuery();
- 57 connection.Close();
- 58 }
- 59
- 60 /**////
- 61 /// 执行SQL语句并返回包含查询结果的DataReader
- 62 ///
- 63 /// 所执行的SQL命令
- 64 /// 参数集合
- 65 ///
- 66 public static OleDbDataReader ExecuteSQLDataReader(string SQLCommand,OleDbParameter[] parameters)
- 67 {
- 68 OleDbConnection connection = new OleDbConnection(GetConnectionString());
- 69 OleDbCommand command = new OleDbCommand(SQLCommand, connection);
- 70
- 71 for (int i = 0; i
- 72 {
- 73 command.Parameters.Add(parameters);
- 74 }
- 75
- 76 connection.Open();
- 77 OleDbDataReader dataReader = command.ExecuteReader();
- 78 //connection.Close();
- 79
- 80 return dataReader;
- 81 }
- 82 }
- 83}
2.实现具体的数据访问操作类
因为前面已经定义了数据访问层接口,所以实现数据访问操作类就是很机械的工作了。下面仅以Admin的数据访问操作类为例:
AdminDAL:
AdminDAL
- 1using System;
- 2using System.Collections.Generic;
- 3using System.Text;
- 4using System.Data;
- 5using System.Data.OleDb;
- 6using NGuestBook.IDAL;
- 7using NGuestBook.Entity;
- 8
- 9namespace NGuestBook.AccessDAL
- 10{
- 11 public class AdminDAL : IAdminDAL
- 12 {
- 13 /**////
- 14 /// 插入管理员
- 15 ///
- 16 /// 管理员实体类
- 17 ///
是否成功 - 18 public bool Insert(AdminInfo admin)
- 19 {
- 20 string SQLCommand = "insert into [TAdmin]([Name],[Password]) values(@name,@password)";
- 21 OleDbParameter[] parameters ={
- 22 new OleDbParameter("name",admin.Name),
- 23 new OleDbParameter("password",admin.Password)
- 24 };
- 25
- 26 try
- 27 {
- 28 AccessDALHelper.ExecuteSQLNonQuery(SQLCommand, parameters);
- 29 return true;
- 30 }
- 31 catch
- 32 {
- 33 return false;
- 34 }
- 35 }
- 36
- 37 /**////
- 38 /// 删除管理员
- 39 ///
- 40 /// 欲删除的管理员的ID
- 41 ///
是否成功 - 42 public bool Delete(int id)
- 43 {
- 44 string SQLCommand = "delete from [TAdmin] where [ID]=@id";
- 45 OleDbParameter[] parameters ={
- 46 new OleDbParameter("id",id)
- 47 };
- 48
- 49 try
- 50 {
- 51 AccessDALHelper.ExecuteSQLNonQuery(SQLCommand, parameters);
- 52 return true;
- 53 }
- 54 catch
- 55 {
- 56 return false;
- 57 }
- 58 }
- 59
- 60 /**////
- 61 /// 更新管理员信息
- 62 ///
- 63 /// 管理员实体类
- 64 ///
是否成功 - 65 public bool Update(AdminInfo admin)
- 66 {
- 67 string SQLCommand = "update [TAdmin] set [Name]=@name,[Password]=@password where [ID]=@id";
- 68 OleDbParameter[] parameters ={
- 69 new OleDbParameter("id",admin.ID),
- 70 new OleDbParameter("name",admin.Name),
- 71 new OleDbParameter("password",admin.Password)
- 72 };
- 73
- 74 try
- 75 {
- 76 AccessDALHelper.ExecuteSQLNonQuery(SQLCommand, parameters);
- 77 return true;
- 78 }
- 79 catch
- 80 {
- 81 return false;
- 82 }
- 83 }
- 84
- 85 /**////
- 86 /// 按ID取得管理员信息
- 87 ///
- 88 /// 管理员ID
- 89 ///
管理员实体类 - 90 public AdminInfo GetByID(int id)
- 91 {
- 92 string SQLCommand = "select * from [TAdmin] where [ID]=@id";
- 93 OleDbParameter[] parameters ={
- 94 new OleDbParameter("id",id)
- 95 };
- 96
- 97 try
- 98 {
- 99 OleDbDataReader dataReader = AccessDALHelper.ExecuteSQLDataReader(SQLCommand, parameters);
- 100 if (!dataReader.HasRows)
- 101 {
- 102 throw new Exception();
- 103 }
- 104
- 105 AdminInfo admin = new AdminInfo();
- 106 dataReader.Read();
- 107 admin.ID=(int)dataReader["ID"];
- 108 admin.Name=(string)dataReader["Name"];
- 109 admin.Password=(string)dataReader["Password"];
- 110
- 111 return admin;
- 112 }
- 113 catch
- 114 {
- 115 return null;
- 116 }
- 117 }
- 118
- 119 /**////
- 120 /// 按用户名及密码取得管理员信息
- 121 ///
- 122 /// 用户名
- 123 /// 密码
- 124 ///
管理员实体类,不存在时返回null - 125 public AdminInfo GetByNameAndPassword(string name, string password)
- 126 {
- 127 string SQLCommand = "select * from [TAdmin] where [Name]=@name and [Password]=@password";
- 128 OleDbParameter[] parameters ={
- 129 new OleDbParameter("name",name),
- 130 new OleDbParameter("password",password),
- 131 };
- 132
- 133 try
- 134 {
- 135 OleDbDataReader dataReader = AccessDALHelper.ExecuteSQLDataReader(SQLCommand, parameters);
- 136 if (!dataReader.HasRows)
- 137 {
- 138 throw new Exception();
- 139 }
- 140
- 141 AdminInfo admin = new AdminInfo();
- 142 dataReader.Read();
- 143 admin.ID = (int)dataReader["ID"];
- 144 admin.Name = (string)dataReader["Name"];
- 145 admin.Password = (string)dataReader["Password"];
- 146
- 147 return admin;
- 148 }
- 149 catch
- 150 {
- 151 return null;
- 152 }
- 153 }
- 154
- 155 /**////
- 156 /// 按管理员名取得管理员信息
- 157 ///
- 158 /// 管理员名
- 159 ///
管理员实体类 - 160 public AdminInfo GetByName(string name)
- 161 {
- 162 string SQLCommand = "select * from [TAdmin] where [Name]=@name";
- 163 OleDbParameter[] parameters ={
- 164 new OleDbParameter("name",name),
- 165 };
- 166
- 167 try
- 168 {
- 169 OleDbDataReader dataReader = AccessDALHelper.ExecuteSQLDataReader(SQLCommand, parameters);
- 170 if (!dataReader.HasRows)
- 171 {
- 172 throw new Exception();
- 173 }
- 174
- 175 AdminInfo admin = new AdminInfo();
- 176 dataReader.Read();
- 177 admin.ID = (int)dataReader["ID"];
- 178 admin.Name = (string)dataReader["Name"];
- 179 admin.Password = (string)dataReader["Password"];
- 180
- 181 return admin;
- 182 }
- 183 catch
- 184 {
- 185 return null;
- 186 }
- 187 }
- 188
- 189 /**////
- 190 /// 取得全部管理员信息
- 191 ///
- 192 ///
管理员实体类集合 - 193 public IList
GetAll() - 194 {
- 195 string SQLCommand = "select * from [TAdmin]";
- 196 try
- 197 {
- 198 OleDbDataReader dataReader = AccessDALHelper.ExecuteSQLDataReader(SQLCommand, null);
- 199 if (!dataReader.HasRows)
- 200 {
- 201 throw new Exception();
- 202 }
- 203
- 204 IList
adminCollection = new List (); - 205 int i = 0;
- 206 while (dataReader.Read())
- 207 {
- 208 AdminInfo admin = new AdminInfo();
- 209 admin.ID = (int)dataReader["ID"];
- 210 admin.Name = (string)dataReader["Name"];
- 211 admin.Password = (string)dataReader["Password"];
- 212
- 213 adminCollection.Add(admin);
- 214 i++;
- 215 }
- 216
- 217 return adminCollection;
- 218 }
- 219 catch
- 220 {
- 221 return null;
- 222 }
- 223 }
- 224 }
- 225}
可以看到,这里主要包括三种类型的操作,一种是修改型,如Insert;一种是返回单个实体类型,如GetByID;还有一种是返回实体类集合型,如GetAll。
MessageDAL和CommentDAL的实现非常相似,在这里不再赘述。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

DDREASE是一种用于从文件或块设备(如硬盘、SSD、RAM磁盘、CD、DVD和USB存储设备)恢复数据的工具。它将数据从一个块设备复制到另一个块设备,留下损坏的数据块,只移动好的数据块。ddreasue是一种强大的恢复工具,完全自动化,因为它在恢复操作期间不需要任何干扰。此外,由于有了ddasue地图文件,它可以随时停止和恢复。DDREASE的其他主要功能如下:它不会覆盖恢复的数据,但会在迭代恢复的情况下填补空白。但是,如果指示工具显式执行此操作,则可以将其截断。将数据从多个文件或块恢复到单

0.这篇文章干了啥?提出了DepthFM:一个多功能且快速的最先进的生成式单目深度估计模型。除了传统的深度估计任务外,DepthFM还展示了在深度修复等下游任务中的最先进能力。DepthFM效率高,可以在少数推理步骤内合成深度图。下面一起来阅读一下这项工作~1.论文信息标题:DepthFM:FastMonocularDepthEstimationwithFlowMatching作者:MingGui,JohannesS.Fischer,UlrichPrestel,PingchuanMa,Dmytr

谷歌力推的JAX在最近的基准测试中性能已经超过Pytorch和TensorFlow,7项指标排名第一。而且测试并不是在JAX性能表现最好的TPU上完成的。虽然现在在开发者中,Pytorch依然比Tensorflow更受欢迎。但未来,也许有更多的大模型会基于JAX平台进行训练和运行。模型最近,Keras团队为三个后端(TensorFlow、JAX、PyTorch)与原生PyTorch实现以及搭配TensorFlow的Keras2进行了基准测试。首先,他们为生成式和非生成式人工智能任务选择了一组主流

在iPhone上面临滞后,缓慢的移动数据连接?通常,手机上蜂窝互联网的强度取决于几个因素,例如区域、蜂窝网络类型、漫游类型等。您可以采取一些措施来获得更快、更可靠的蜂窝互联网连接。修复1–强制重启iPhone有时,强制重启设备只会重置许多内容,包括蜂窝网络连接。步骤1–只需按一次音量调高键并松开即可。接下来,按降低音量键并再次释放它。步骤2–该过程的下一部分是按住右侧的按钮。让iPhone完成重启。启用蜂窝数据并检查网络速度。再次检查修复2–更改数据模式虽然5G提供了更好的网络速度,但在信号较弱

哭死啊,全球狂炼大模型,一互联网的数据不够用,根本不够用。训练模型搞得跟《饥饿游戏》似的,全球AI研究者,都在苦恼怎么才能喂饱这群数据大胃王。尤其在多模态任务中,这一问题尤为突出。一筹莫展之际,来自人大系的初创团队,用自家的新模型,率先在国内把“模型生成数据自己喂自己”变成了现实。而且还是理解侧和生成侧双管齐下,两侧都能生成高质量、多模态的新数据,对模型本身进行数据反哺。模型是啥?中关村论坛上刚刚露面的多模态大模型Awaker1.0。团队是谁?智子引擎。由人大高瓴人工智能学院博士生高一钊创立,高

最近,军事圈被这个消息刷屏了:美军的战斗机,已经能由AI完成全自动空战了。是的,就在最近,美军的AI战斗机首次公开,揭开了神秘面纱。这架战斗机的全名是可变稳定性飞行模拟器测试飞机(VISTA),由美空军部长亲自搭乘,模拟了一对一的空战。5月2日,美国空军部长FrankKendall在Edwards空军基地驾驶X-62AVISTA升空注意,在一小时的飞行中,所有飞行动作都由AI自主完成!Kendall表示——在过去的几十年中,我们一直在思考自主空对空作战的无限潜力,但它始终显得遥不可及。然而如今,

这周,由OpenAI、微软、贝佐斯和英伟达投资的机器人公司FigureAI宣布获得接近7亿美元的融资,计划在未来一年内研发出可独立行走的人形机器人。而特斯拉的擎天柱也屡屡传出好消息。没人怀疑,今年会是人形机器人爆发的一年。一家位于加拿大的机器人公司SanctuaryAI最近发布了一款全新的人形机器人Phoenix。官方号称它能以和人类一样的速率自主完成很多工作。世界上第一台能以人类速度自主完成任务的机器人Pheonix可以轻轻地抓取、移动并优雅地将每个对象放置在它的左右两侧。它能够自主识别物体的

多模态文档理解能力新SOTA!阿里mPLUG团队发布最新开源工作mPLUG-DocOwl1.5,针对高分辨率图片文字识别、通用文档结构理解、指令遵循、外部知识引入四大挑战,提出了一系列解决方案。话不多说,先来看效果。复杂结构的图表一键识别转换为Markdown格式:不同样式的图表都可以:更细节的文字识别和定位也能轻松搞定:还能对文档理解给出详细解释:要知道,“文档理解”目前是大语言模型实现落地的一个重要场景,市面上有很多辅助文档阅读的产品,有的主要通过OCR系统进行文字识别,配合LLM进行文字理
