.NET数据库工厂模式简单实现

通过改变配置文件实现访问不同数据库的工厂模式。

ExpandedBlockStart.gif 代码
using  System;
using  System.Data;
using  System.Configuration;
using  System.Collections;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;
using  System.Data.Common;
public   partial   class  DataBaseFactory : System.Web.UI.Page
{
    
private  DbConnection con;
    
private  DbCommand cmd;
    
private  DbProviderFactory provider;
    
public  DataBaseFactory()
    {
        
string  providerName  =  ConfigurationManager.ConnectionStrings[ 1 ].ProviderName;
        provider 
=  DbProviderFactories.GetFactory(providerName);
        con 
=  provider.CreateConnection();
        con.ConnectionString 
=  ConfigurationManager.ConnectionStrings[ 1 ].ConnectionString;
        cmd 
=  provider.CreateCommand();
        cmd.Connection 
=  con;
    }
   
public  DataTable getAlarmTable( string  sql)
    {
        
if  (con  !=   null )
        {
            
try
            {
                DataSet ds 
=   new  DataSet();
                DbDataAdapter da 
=  provider.CreateDataAdapter(sql, con);
                da.Fill(ds);
                da.Dispose();
                
return  ds.Tables[ 0 ];
            }
            
catch  (Exception e)
            {
                
// 2010.01.26  注释打印信息,添加Log日志。
                Program.WriteLog(e.Message.ToString());
                
// Console.WriteLine(e.Message);
                 return   null ;
            }
            
finally
            {
                
if  (con !=   null )
                {
                    con.Close();
                }
            }
        }
        
else
        {
            Console.WriteLine(DateTime.Now.ToString() 
+   "  没有连接到数据库 " );
            
return   null ;
        }
    }   
}

 

 

转载于:https://www.cnblogs.com/gooliugle/archive/2010/04/24/1719579.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值