public interface IDbHelper
{
void ExecuteNonQuery();
DataSet ExecuteForDataSet(string sql);
}
internal class SqlDbHelper:IDbHelper
{
public SqlDbHelper()
{
}
public void ExecuteNonQuery()
{
}
public DataSet ExecuteForDataSet(string sql)
{
//这里实现sqlserver的方法
return null;
}
}
internal class OleDbHelper:IDbHelper
{
public OleDbHelper()
{
}
public void ExecuteNonQuery()
{
}
public DataSet ExecuteForDataSet(string sql)
{
//这里实现oledb的方法
return null;
}
public class DbHelperFactory
{
public static IDbHelper CreateDbHelper(int DbType)
{
switch(DbType)
{
case 1:
return new SqlDbHelper();
case 2:
return new OleDbHelper();
default:
return null;
}
}
}
public class AbstractFactoryTest
{
public void TestMethod()
{
IDbHelper sqldb=DbHelperFactory.CreateDbHelper(1);
sqldb.ExecuteNonQuery();
}
}
这个时候我们就可以很方便的调用数据库组件了,在调用CreateDbHelper方法时,传入参数为1,那么就是调用SqlDbHelper这个类,传入参数为2,那么就是调用OleDbHelper这个类。当然传入的参数你还可以把它变为枚举型,这样就更加方便了。