基于.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脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++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提供了更好的網路速度,但在訊號較弱

多模態文件理解能力新SOTA!阿里mPLUG團隊發布最新開源工作mPLUG-DocOwl1.5,針對高解析度圖片文字辨識、通用文件結構理解、指令遵循、外部知識引入四大挑戰,提出了一系列解決方案。話不多說,先來看效果。複雜結構的圖表一鍵識別轉換為Markdown格式:不同樣式的圖表都可以:更細節的文字識別和定位也能輕鬆搞定:還能對文檔理解給出詳細解釋:要知道,“文檔理解”目前是大語言模型實現落地的一個重要場景,市面上有許多輔助文檔閱讀的產品,有的主要透過OCR系統進行文字識別,配合LLM進行文字理

特斯拉機器人Optimus最新影片出爐,已經可以在工廠裡打工了。正常速度下,它分揀電池(特斯拉的4680電池)是這樣的:官方還放出了20倍速下的樣子——在小小的「工位」上,揀啊揀啊揀:這次放出的影片亮點之一在於Optimus在廠子裡完成這項工作,是完全自主的,全程沒有人為的干預。而且在Optimus的視角之下,它還可以把放歪了的電池重新撿起來放置,主打一個自動糾錯:對於Optimus的手,英偉達科學家JimFan給出了高度的評價:Optimus的手是全球五指機器人裡最靈巧的之一。它的手不僅有觸覺

哭死啊,全球狂煉大模型,一網路的資料不夠用,根本不夠用。訓練模型搞得跟《飢餓遊戲》似的,全球AI研究者,都在苦惱怎麼才能餵飽這群資料大胃王。尤其在多模態任務中,這問題尤其突出。一籌莫展之際,來自人大系的初創團隊,用自家的新模型,率先在國內把「模型生成數據自己餵自己」變成了現實。而且還是理解側和生成側雙管齊下,兩側都能產生高品質、多模態的新數據,對模型本身進行數據反哺。模型是啥?中關村論壇上剛露面的多模態大模型Awaker1.0。團隊是誰?智子引擎。由人大高瓴人工智慧學院博士生高一鑷創立,高

FP8和更低的浮點數量化精度,不再是H100的「專利」了!老黃想讓大家用INT8/INT4,微軟DeepSpeed團隊在沒有英偉達官方支援的條件下,硬生在A100上跑起FP6。測試結果表明,新方法TC-FPx在A100上的FP6量化,速度接近甚至偶爾超過INT4,而且比後者擁有更高的精度。在此基礎之上,還有端到端的大模型支持,目前已經開源並整合到了DeepSpeed等深度學習推理框架中。這項成果對大模型的加速效果也是立竿見影──在這種框架下用單卡跑Llama,吞吐量比雙卡還要高2.65倍。一名
