您的位置:首页 > 编程语言 > C#

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

2016-06-03 00:36 429 查看


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



最讨厌写文章贴代码片段,学习过程中想重现的时候困难重重。项目代码上传到我的资源了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mQney c#