• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
gooliugle
博客园    首页    新随笔    联系   管理    订阅  订阅
.NET数据库工厂模式简单实现

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

代码
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;
        }
    }   
}

 

 

posted on 2010-04-24 22:22  gooliugle  阅读(445)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3