经过上面篇文章的介绍,整个系统的 框架 算是基本搭建完了,下面,我们要具体 实现 各个层次。关于 数据 访问 层的 实现 ,我准备讨论三种 实现 方式,这一篇文章讨论 第一 种: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的实现非常相似,在这里不再赘述。

MySQL은 초보자가 데이터베이스 기술을 배우는 데 적합합니다. 1. MySQL 서버 및 클라이언트 도구를 설치하십시오. 2. SELECT와 같은 기본 SQL 쿼리를 이해하십시오. 3. 마스터 데이터 작업 : 데이터를 만들고, 삽입, 업데이트 및 삭제합니다. 4. 고급 기술 배우기 : 하위 쿼리 및 창 함수. 5. 디버깅 및 최적화 : 구문 확인, 인덱스 사용, 선택*을 피하고 제한을 사용하십시오.

MySQL은 테이블 구조 및 SQL 쿼리를 통해 구조화 된 데이터를 효율적으로 관리하고 외래 키를 통해 테이블 간 관계를 구현합니다. 1. 테이블을 만들 때 데이터 형식을 정의하고 입력하십시오. 2. 외래 키를 사용하여 테이블 간의 관계를 설정하십시오. 3. 인덱싱 및 쿼리 최적화를 통해 성능을 향상시킵니다. 4. 데이터 보안 및 성능 최적화를 보장하기 위해 데이터베이스를 정기적으로 백업 및 모니터링합니다.

MySQL은 웹 개발에 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 주요 기능에는 다음이 포함됩니다. 1. 다른 시나리오에 적합한 InnoDB 및 MyISAM과 같은 여러 스토리지 엔진을 지원합니다. 2.로드 밸런싱 및 데이터 백업을 용이하게하기 위해 마스터 슬레이브 복제 기능을 제공합니다. 3. 쿼리 최적화 및 색인 사용을 통해 쿼리 효율성을 향상시킵니다.

SQL은 MySQL 데이터베이스와 상호 작용하여 데이터 첨가, 삭제, 수정, 검사 및 데이터베이스 설계를 실현하는 데 사용됩니다. 1) SQL은 Select, Insert, Update, Delete 문을 통해 데이터 작업을 수행합니다. 2) 데이터베이스 설계 및 관리에 대한 생성, 변경, 삭제 문을 사용하십시오. 3) 복잡한 쿼리 및 데이터 분석은 SQL을 통해 구현되어 비즈니스 의사 결정 효율성을 향상시킵니다.

MySQL의 기본 작업에는 데이터베이스, 테이블 작성 및 SQL을 사용하여 데이터에서 CRUD 작업을 수행하는 것이 포함됩니다. 1. 데이터베이스 생성 : createAbasemy_first_db; 2. 테이블 만들기 : CreateTableBooks (idintauto_incrementprimarykey, titlevarchar (100) notnull, authorvarchar (100) notnull, published_yearint); 3. 데이터 삽입 : InsertIntobooks (Title, Author, Published_year) VA

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

MySQL 데이터베이스를 구축하는 단계에는 다음이 포함됩니다. 1. 데이터베이스 및 테이블 작성, 2. 데이터 삽입 및 3. 쿼리를 수행하십시오. 먼저 CreateAbase 및 CreateTable 문을 사용하여 데이터베이스 및 테이블을 작성한 다음 InsertInto 문을 사용하여 데이터를 삽입 한 다음 최종적으로 SELECT 문을 사용하여 데이터를 쿼리하십시오.

MySQL은 사용하기 쉽고 강력하기 때문에 초보자에게 적합합니다. 1.MySQL은 관계형 데이터베이스이며 CRUD 작업에 SQL을 사용합니다. 2. 설치가 간단하고 루트 사용자 비밀번호를 구성해야합니다. 3. 삽입, 업데이트, 삭제 및 선택하여 데이터 작업을 수행하십시오. 4. Orderby, Where and Join은 복잡한 쿼리에 사용될 수 있습니다. 5. 디버깅은 구문을 확인하고 쿼리를 분석하기 위해 설명을 사용해야합니다. 6. 최적화 제안에는 인덱스 사용, 올바른 데이터 유형 선택 및 우수한 프로그래밍 습관이 포함됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)
