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();
}
}
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;
}
}
}
<?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();
}
}
}
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
最讨厌写文章贴代码片段,学习过程中想重现的时候困难重重。项目代码上传到我的资源了。