继续上一篇《http://www.cnblogs.com/insus/p/3825805.html 。我们学会了怎样创建对象,把BizBase类从页面级分离,解耦合度。亲的更亲,疏的更疏。

上面使用的是Access数据,将达不到扩展与升级的要求。程序在发展的同时,有可能会转向SQL数据库,或是有些模块外包。在这情形出现,我们需要定制设计规范接口。接手此软开发的团队,所在逻辑处层中,实作这个接口即可。

下面Insus.NET尝试写一个接口,在程序中应用SQL Server的团队,不管是在逻辑层中写SQL语句的,还是在逻辑层传入参数引用存储过程的,均可实现统一的接口。

ASP.NET开发,从二层至三层,至面向对象 (3)


上面标记2的返回DbdataReader函数,是为了它能让Access数据库(System.Data.OleDb.OleDbDataReader)与SQL数据库(System.Data.SqlClient.SqlDataReader)均能实作。由于这两者均是继承DbDataReader类。

这样的话,以前写的Access数据库的逻辑类BizBase,实作这个接口,得修改一下,才符合接口的标准:
ASP.NET开发,从二层至三层,至面向对象 (3)


下面,Insus.NET实现一个逻辑类,是方便用用户在程序的中习惯写SQL语句的对象:
ASP.NET开发,从二层至三层,至面向对象 (3)


接下来,Insus.NET再实现一个逻辑处理类,也是程序与数据库互通的,不过它是配合SQL Server数据库的存储过程来的。当然使用存储过程,它自然有参数出现。准备之前,先写一个类Insus.NET.Parameter:

ASP.NET开发,从二层至三层,至面向对象 (3)

 

 现在就可以创建这个逻辑类了,它有实作接口IBiz:
ASP.NET开发,从二层至三层,至面向对象 (3)


上面有写两个public的property,将是用来给程序对象传入引用的哪一个存储过程,以及参数。如果所引用的存储过程没有参数,传入null即可。

        private string _ProcedureName;
        private List<Parameter> _Parameters;

        public string ProcedureName
        {
            get { return _ProcedureName; }
            set { _ProcedureName = value; }
        }
        public List<Parameter> Parameters
        {
            get { return _Parameters; }
            set { _Parameters = value; }
        }
View Code

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-24
  • 2021-12-25
  • 2022-12-23
  • 2021-12-04
猜你喜欢
  • 2021-08-02
  • 2021-12-04
  • 2021-10-25
  • 2021-09-14
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案