您好,
首先,我对于这个“三层访问方法”不是很理解……最近比较笨。
如果您说的是数据库软件的三层模型(表示层、业务逻辑层、数据访问层)的话,这个的确是涉及数据库软件很常见的架构,访问数据的工作完全由DAL也就是数据访问层来做。
至于您说的“实体和数据库表映射类”,我是不是可以理解为,用若干个类完全映射数据库中数据表的物理结构。
这个设计的想法很不错哦~很像MS的PetShop。
说了不少废话,其实应该是由DAL访问数据库并填充Model类的具体实例,然后返回这个实例由上层代码使用,我随便写了个代码,希望对您有帮助:
首先DALcs
using System;
using SystemData;
using SystemDataOleDb;
class DAL{
public Employee GetFirstEmployee()
{
OleDbConnection
此处省略一些代码,包括SQL语句
}
}
这个DAL返回一个Employee类型的实例,里面保存了数据库中Employee表中第一个雇员的信息。
Model中Employee类
class Employee
{
int age;
string name;
}
然后上层使用的时候,直接调用DALGetFirstEmployee()方法得到第一个雇员的信息。
我可能解释的不是很清楚,而且这也不是最好的设计,比如DAL一般要涉及到工厂模式,如果您仍有疑问,希望您补充问题。
============================================
对补充的答复:
其实大一些的软件大多会涉及到设计模式这种东西~~
软件设计是跟着前面的需求分析来做的,所以数据访问层可能会有些不同但这个层应该是属于相对稳定的模块
根据软件设计的原理,要尽量保持模块间的独立性因此,数据访问层中应该尽量只包括访问数据库的代码
上面的代码比较简单,下面写个稍复杂点的:)
此DAL可以用来连接Oracle\Access\SQL Server数据库分为5个类
sealed class DalFactory{
public static DAL CreateDal()
{
//Here read the configuration file
//and return the certain child class of DAL
//for example
//假设这里读取到的配置是SQL数据库
return new SqlServerDal();
}
}
//基类DAL
public abstract class DAL
{
public abstract Employee GetFirstEmployee();
}
//我只写了一个方法返回第一个雇员信息
//SQL Server 实现类SqlServerDal
public class SqlServerDal : DAL
{
public Employee GetFirstEmployee()
{
//sql 连接数据库
}
}
//OLE实现类 OleDbDal
public class OleDbDal : DAL
{
public Employee GetFirstEmployee()
{
//OLE 连接数据库
}
}
//ODBC实现类 OdbcDbDal
public class OdbcDbDal : DAL
{
public Employee GetFirstEmployee()
{
//OLE 连接数据库
}
}
大概就是这个样子,这只是一个想法,我以前写过个类似的程序,就是这个架构。
继承和多态是OOA/OOD/OOP最有力的东西,比如这里,把DAL的子类当作DAL返回,上层BLL代码就无需关心下面是什么DBMS。
SQL语句我倾向于单独放到某个类里做成Public Const变量(如果经常变化的话),或者放到Model类里。
OOA的核心思想就是“发现并封装变化点”。
具体的代码我没有写,那个太多了,如果您需要,可以继续补充问题~~呵呵
dal是数据访问层的英文缩写,即为数据访问层(Data Access Layer)。其功能主要是负责数据库的访问。简单地说就是实现对数据表的Select(查询)、Insert(插入)、Update(更新)、Delete(删除)等 *** 作。
中文名
DAL为数据访问层
外文名
Data Access Layer
结构层数
3层
别称
DAL层
定义
主要是负责数据库的访问
以上就是关于c#中使用三层访问方法中如何连接数据库,与model(实体和数据库表映射类)怎么连接的需要代码和解释。全部的内容,包括:c#中使用三层访问方法中如何连接数据库,与model(实体和数据库表映射类)怎么连接的需要代码和解释。、在WebServive中DAL层怎么写修改的方法、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)