学习设计模式的时候,提到了一个专门访问数据库的模式-抽象工厂模式,记得当时举例子理解的时候并未设计到数据库,只是大概了了解了一下,现在对于机房收费系统涉及到了数据库的管理,借此机会好好学习一下。用经常说的一句经典的话语则是:欠的债总是要还的,这句话同时也警告自己对于学习要一心一意,切勿粗心大意。
欢迎访问自己对于工厂三姐妹的理解
对比可以知道,对于抽象工厂模式的初步理解,则是
重构机房收费系统,对于数据库的选择方法则是在D层建立一个单独的类,来连接字符串。而在此使用工厂层,其主要作用就是应用配置文件和反射技术实现数据库的更换功能。
在Factory中首先定义程序集的名字和命名空间的名字,将程序集的名字和命名空间的的值写在配置文件中,这样当执行到Factory函数时程序会自动通过读取配饰文件中的相应字符,按照路径实例化出相应的对象。
对于配置文件的配置如下:
以上是最为简单的应用程序配置文件的例子,在appSettings中添加自己所用的参数就可。记住不要忘记引用程序集中的 System.configuration.
其次在程序开头增加:
代码实现:
使用ConfigurationManager的静态属性AppSettings就可以直接访问配置文件中的配置信息
Dim sqlConnection as string=ConfigurationManager.AppSettings("strConnection") '对sqlConnection赋值
factory中的代码:
- '********************************
- '说明:应用配置文件和反射技术实现数据库的更换功能
- '作者:霍亚静
- '小组:XX
- '创建日期:2014/6/14 19:44:35
- '版本号:V1.00
- '********************************
- Imports System.Configuration '添加对配置文件的使用
- Imports System.Reflection '添加对反射的引用
- Imports IDAL
- Public Class DataAccess
- Private strassembly As String '程序集名
- '''<summary>
- '''构造函数,通过调用配置文件为Strassembly赋初值
- '''</summary>
- Sub New()
- Me.strassembly = ConfigurationManager.appSettings("<span style="color:#ff0000;">Charge1</span>") & "DAL" 'Charge1为自己的数据库名字
- End Sub
- '''<summary>
- ''' 实例化接口为IUser为UserDAL
- '''</summary>
- ''' <returns>IUser</returns>
- Public Function CreateUserDAL() As IUser
- Dim strIntance As String = strassembly & "." & "UserDAL" '所要实例的对象(程序集与命名空间同名)
- Return CType(Assembly.Load(strassembly).CreateInstance(strIntance), IUser) '返回IUser ,Iuser为DAL的接口
- End Function
- End Class
'********************************
'说明:应用配置文件和反射技术实现数据库的更换功能
'作者:霍亚静
'小组:XX
'创建日期:2014/6/14 19:44:35
'版本号:V1.00
'********************************
Imports System.Configuration '添加对配置文件的使用
Imports System.Reflection '添加对反射的引用
Imports IDAL
Public Class DataAccess
Private strassembly As String '程序集名
'''<summary>
'''构造函数,通过调用配置文件为Strassembly赋初值
'''</summary>
Sub New()
Me.strassembly = ConfigurationManager.appSettings("<span style="color:#ff0000;">Charge1</span>") & "DAL" 'Charge1为自己的数据库名字
End Sub
'''<summary>
''' 实例化接口为IUser为UserDAL
'''</summary>
''' <returns>IUser</returns>
Public Function CreateUserDAL() As IUser
Dim strIntance As String = strassembly & "." & "UserDAL" '所要实例的对象(程序集与命名空间同名)
Return CType(Assembly.Load(strassembly).CreateInstance(strIntance), IUser) '返回IUser ,Iuser为DAL的接口
End Function
End Class
对于配置文件的使用相信我们在学习的过程中会应用的更加熟练,继续磨练中……