&
经过上面篇文章的介绍,整个系统的框架算是基本搭建完了,下面,我们要具体实现各个层次。关于数据访问层的实现,我准备讨论三种实现方式,这一篇文章讨论第一种:Access+动态生成SQL。
顾名思义,这种实现将使用Access作为后台数据库,而操作方式也是最基本的使用SQL命令。
在具体编写实现代码之前,我们需要做一些准备工作:
第一步,我们要将Access数据库搭建完成,具体做法如下。
在Web工程下新建一个文件夹,命名为AccessData,并在其中新建一个mdb文件(即Access数据库文件),按照前面介绍过的数据库设计构架,将数据表及表间关系建好,这里不再赘述。
第二步,我们要进行一些配置。
打开Web工程下的Web.config文件,在其中的appSettings节点下,添加如下键值:
<add key="AccessConnectionString" value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source={DBPath}"/>
<add key="AccessPath" value="~/AccessData/AccessDatabase.mdb"/>
第一条为Access的连接字符串,第二条为Access数据库文件的路径,其中“~”表示网站根目录。
第三步,新建一个工程。
我们要新建一个工程AccessDAL,用来存放Access数据访问层的代码。
准备工作做完了,现在来实现具体的代码。
1.编写数据访问助手类
因为很多数据访问操作流程很相似,所以,这里将一些可复用的代码抽取出来,编写成助手类,以此减少代码量,提高代码复用性。
这个助手类放在AccessDAL下,叫AccessDALHelper,主要负责Access数据库的访问。它包括三个方法:
GetConnectionString:从配置文件中读取配置项,组合成连接字符串。
ExecuteSQLNonQuery:执行指定SQL语句,不返回任何值,一般用于Insert,Delete,Update命令。
ExecuteSQLDataReader:执行SQL语句返回查询结果,一般用于Select命令。
具体代码如下:
AccessDALHelper.cs:
1
using
System;
2
using
System.Web;
3
using
System.Web.Caching;
4
using
System.Configuration;
5
using
System.Data;
6
using
System.Data.OleDb;
7
using
NGuestBook.Utility;
8
9
namespace
NGuestBook.AccessDAL
10
{
11
///
<summary>
12
///
Access数据库操作助手
13
///
</summary>
14
public
sealed
class
AccessDALHelper
15
{
16
///
<summary>
17
///
读取Access数据库的连接字符串
18
///
首先从缓存里读取,如果不存在则到配置文件中读取,并放入缓存
19
///
</summary>
20
///
<returns>
Access数据库的连接字符串
</returns>
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}
" lt;/span>, dbAbsolutePath), fileDependency);
35
36 return connectionString.Replace("{DBPath}", dbAbsolutePath);
37 }
38 }
39
40 /// <summary>
41 /// 执行SQL语句并且不返回任何值
42 /// </summary>
43 /// <param name="SQLCommand">所执行的SQL命令</param>
44 /// <param name="parameters">参数集合</param>
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 < parameters.Length; i++)
51 {
52 command.Parameters.Add(parameters[i]);
53 }
54
55 connection.Open();
56 command.ExecuteNonQuery();
57 connection.Close();
58 }
59
60 /// <summary>
61 /// 执行SQL语句并返回包含查询结果的DataReader
62 /// </summary>
63 /// <param name="SQLCommand">所执行的SQL命令</param>
64 /// <param name="parameters">参数集合</param>
65 /// <returns></returns>
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 < parameters.Length; i++)
72 {
73 command.Parameters.Add(parameters[i]);
74 }
75
76 connection.Open();
77 OleDbDataReader dataReader = command.ExecuteReader();
78 //connection.Close();
79
80 return dataReader;
81 }
82 }
83}
2.实现具体的数据访问操作类
因为前面已经定义了数据访问层接口,所以实现数据访问操作类就是很机械的工作了。下面仅以Admin的数据访问操作类为例:
AdminDAL:
1
using
System;
2
using
System.Collections.Generic;
3
using
System.Text;
4
using
System.Data;
5
using
System.Data.OleDb;
6
using
NGuestBook.IDAL;
7
using
NGuestBook.Entity;
8
9
namespace
NGuestBook.AccessDAL
10
{
11
public
class
AdminDAL : IAdminDAL
12
{
13
///
<summary>
14
///
插入管理员
15
///
</summary>
16
///
<param name="admin">
管理员实体类
</param>
17
///
<returns>
是否成功
</returns>
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
///
<summary>
38
///
删除管理员
39
///
</summary>
40
///
<param name="id">
欲删除的管理员的ID
</param>
41
///
<returns>
是否成功
</returns>
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
///
<summary>
61
///
更新管理员信息
62
///
</summary>
63
///
<param name="admin">
管理员实体类
</param>
64
///
<returns>
是否成功
</returns>
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
///
<summary>
86
///
按ID取得管理员信息
87
///
</summary>
88
///
<param name="id">
管理员ID
</param>
89
///
<returns>
管理员实体类
</returns>
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
///
<summary>
120
///
按用户名及密码取得管理员信息
121
///
</summary>
122
///
<param name="name">
用户名
</param>
123
///
<param name="password">
密码
</param>
124
///
<returns>
管理员实体类,不存在时返回null
</returns>
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
///
<summary>
156
///
按管理员名取得管理员信息
157
///
</summary>
158
///
<param name="name">
管理员名
</param>
159
///
<returns>
管理员实体类
</returns>
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
///
<summary>
190
///
取得全部管理员信息
191
///
</summary>
192
///
<returns>
管理员实体类集合
</returns>
193
public
IList
<
AdminInfo
>
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
<
AdminInfo
>
adminCollection
=
new
List
<
AdminInfo
>
();
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的实现非常相似,在这里不再赘述。