C#三层结构双数据源复习


1,支持oracle数据库sql数据库,工厂通过配置文件选择数据库。

2,在win7系统64位上vs2010链接oracle10g并不成功,报错是【Oracle.DataAccess.Client.OracleException: ORA-12154: TNS: 无法解析指定的连接标识符】。但是发布到IIS就可以运行。这是一个bug。

3,System.Data.OracleClient.OracleConnection提示已过时,用Oracle.DataAccess.Client.OracleConnection代替。在oracle安装目录搜索即可,我的是【E:\oracle\product\10.2.0\db_1\odp.net\bin\2.x\Oracle.DataAccess.dll】

4,想要直接运行此代码,需要修改数据库连接字符串【web.config中内容】,还有DAL中查询语句【select * from 表】

下面贴代码之前,先贴一个结构图:


1,BLL项目,逻辑层,表现层的所有数据操作都指向这里。而这里的方法全部调用IDAL接口。


using System;
using System.Collections.Generic;
using System.Text;
using IDAL;
using DALFactory;


namespace BLL
{
    public class BLLManager
    {      //从工厂里面创建数据访问类
        private static readonly IManager IDal = DataAccess.Create_DALManager();
        //public BLLManager()
        //{ 
        //这里不能有默认构造函数,否则不执行IDal的初始化
        //}
        /// <summary>
        /// 工厂模式测试
        /// 根据配置文件成功切换DAL即为成功
        /// </summary>
        /// <returns></returns>
        public static string TestDb()
        {
            return IDal.TestDb();
        }
        /// <summary>
        /// 测试数据库连接成功
        /// </summary>
        /// <returns></returns>
        public static string TestQuery()
        {
            return IDal.TestQuery();
        }
    }
}

2,IDAL接口,


using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using Model;


namespace IDAL
{
    /// <summary>
    ///  IManager
    /// author CYTD Young
    /// 2016/6/2 16:44:51
    /// music: 
    /// </summary>
    public interface IManager
    {
        /// <summary>
        /// 
        /// </summary>
        /// <returns></returns>
        string TestDb();


        string TestQuery();
    }
}


3,DALFactory,工厂,负责根据配置文件内容,决定使用什么数据库源,即把业务层BLL交给接口IDAL的查询任务,交给SQLDAL还是ORACLEDAL。

web.config,包含在主项目中。虽然在工厂DALFactory中读取,但是文件还是在主程序中。工厂中使用

ConfigurationManager.AppSettings["DAL"];

读取配置文件中key为DAL的值,然后再反射出不同的DAL。


using System;
using System.Collections.Generic;
using System.Text;
using System.Reflection;
using System.Configuration;
using IDAL;

namespace DALFactory
{
    //<summary>
    //在抽象工厂中创建DAL对象
    //</summary>
    public sealed class DataAccess
    {
        //从配置文件读取DAL的键值
        private static readonly string AssemblyPath = ConfigurationManager.AppSettings["DAL"];
        //<summary>
        //创建数据层接口
        //</summary>
        public static IDAL.IManager CreateManager()
        {
            //组合需要反射的 类名称str字符串,应该是OracleDAL.DALManager或者SQLServerDAL.DALManager
            string classNamespace = AssemblyPath + ".Manager";
            //人间大炮,反射
            object objType = Assembly.Load(AssemblyPath).CreateInstance(classNamespace);
            //类型转换
            return (IManager)objType;
        }

        public static IManager Create_DALManager()
        {
            //这个是配置文件写包名,程序自己加.类名
            string className = AssemblyPath + ".DALManager";
            #region 反射当前程序集
             获取当前程序集
            //Assembly assembly = System.Reflection.Assembly.GetExecutingAssembly();
            创建类的实例("类的完全限定名(即包括命名空间)");
            //object objType = assembly.CreateInstance(className);
            #endregion

            #region 反射其他程序集DLL
            // 加载程序集(EXE 或 DLL) 
            //Assembly assembly = Assembly.Load("MyAssembly");if (assembly != null){ Console.WriteLine("加载成功"); }
            //Assembly.LoadFrom(@"C:\ABC\Test.dll");
            //LoadFile()不会解析任何依赖;LoadFile()可以多次加载同一程序集
            Assembly assembly = Assembly.Load(AssemblyPath);
            //创建类的实例 "类的完全限定名(即包括命名空间)"
            object objType = assembly.CreateInstance(className);
            //类型初始值设定项引发异常。反射动态加载程序集是通过这种方法 Assembly.Load("程序集").CreateInstance("命名空间.类"),其中的“程序集”读取的是解决方案入口Web层bin文件夹下对应的dll,即反射加载的程序集dll在Web层的bin文件夹必须有,不然就会出现如题的错误。
            #endregion
            return (IManager)objType;
        }
    }
}


4,主程序,入口程序。主要介绍一下web.config。Sql2005ConnectionString与Sql2008ConnectionString是我机器上两个版本的库。OracleConnectionString1与OracleConnectionString是我机器上oracle10g的库,VS中F5测试不可以【ORA-12154: TNS: 无法解析指定的连接标识符】,发布到IIS以后都可以连接。也可以把地址写在appSettings中通过键值来定义,但是connectionStrings是被推荐使用的,appSettings现在不推荐。


<?xml version="1.0"?>
<configuration>
  <appSettings>
    <add key="DAL2" value="SQLServerDAL"/>
    <add key="DAL" value="OracleDAL"/>
  </appSettings>
  <connectionStrings>
    <add name="Sql2005ConnectionString" connectionString="Server=localhost;Database=CYYFCheckUpV5;Uid=adm;Password=admpass"/>
    <add name="Sql2008ConnectionString" connectionString="Server=localhost\MSSQLSERVER2008;Database=CYYFCheckUpV5_XJ_BZ;Uid=adm;Password=admpass"/>
    <add name="OracleConnectionString1" connectionString="Data Source=(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521)))(CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME = orcl)));User Id=adm;Password=admpass;"/>
    <add name="OracleConnectionString" connectionString="Data Source=127.0.0.1/orcl;User Id=adm;Password=admpass;"/>
  </connectionStrings>
  <system.web>
    <compilation debug="true" targetFramework="4.0"/>
    <authentication mode="Windows"/>
    <pages controlRenderingCompatibilityVersion="3.5" clientIDMode="AutoID"/>
  </system.web>
</configuration>


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using BLL;

namespace CYYFReportDataService
{
    /// <summary>
    /// KendrickLamar 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
    // [System.Web.Script.Services.ScriptService]
    public class KendrickLamar : System.Web.Services.WebService
    {

        [WebMethod]
        public string HelloWorld()
        {
            return "Hello World";
        }
        [WebMethod]
        public string TestDb()
        {
            return BLLManager.TestDb();
        }
        [WebMethod]
        public string TestQuery()
        {
            return BLLManager.TestQuery();
        }
    }
}



5,SQLDAL。sql的一揽子解决方案。


6,ORACLE的一揽子解决方案



7,ConfigurationManager和WebConfigurationManager,web程序用WebConfigurationManager

使用:private static readonly string AssemblyPath = ConfigurationManager.AppSettings["DAL"];
class:ConfigurationManager
namespace:System.Configuration
dll:System.Configuration.dll


使用:string connStr = WebConfigurationManager.ConnectionStrings["OracleConnectionString"] == null ? "" :WebConfigurationManager.ConnectionStrings["OracleConnectionString"].ToString();

class:WebConfigurationManager

namespace:System.Web.Configuration
dll:System.Web.dll

8,公共类


9,作为摆设的Model



最讨厌写文章贴代码片段,学习过程中想重现的时候困难重重。项目代码上传到我的资源了。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值