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
最讨厌写文章贴代码片段,学习过程中想重现的时候困难重重。项目代码上传到我的资源了。
相关文章推荐
- c#调用COM组件
- C#实现把指定数据写入串口
- C#动态创建button的方法
- C#中抽象方法与虚拟方法的区别
- c#中虚函数的相关使用方法
- C#实现给图片加水印的方法
- C#使用加边法计算行列式的值
- C#实现多线程的同步方法实例分析
- C#中尾递归的使用、优化及编译器优化
- C#中的delegate委托类型基本学习教程
- C#实现子窗体与父窗体通信方法实例总结
- C#通用邮件发送类分享
- 举例讲解C#中自动实现的属性
- C#中this的用法集锦
- C#数据结构之顺序表(SeqList)实例详解
- C#.NET获取拨号连接的宽带连接方法
- C#异步绑定数据实现方法
- C#实现AddRange为数组添加多个元素的方法
- C#中Equality和Identity浅析
- C#比较二个数组并找出相同或不同元素的方法