先讲一下简单工厂模式、工厂方法模式、抽象工厂模式的东西:
简单工厂并不属于23种基本设计模式中,它是抽象工厂模式的一个特例;抽象工厂与工厂方法区别在于它们抽象的对象不同:工厂方法针对产品进行抽象,而抽象工厂抽象针对工厂。因此可以认为工厂方法是抽象工厂的一种极端情况,工厂方法模式用来创建一个产品的等级结构,它一般只有一个方法,创建一种产品;而抽象工厂是用来创建多个产品的等级结构,一般有多个方法,创建一系列产品。
手机号码查询设计
此程序主要功能就是根据手机号码段查询相应的号码归属地。数据来自网络,数据表结构如下
数据记录超过17万条
这里我使用了Sqlite数据库,将此数据库文件转换为Sqlite数据库文件。
主程序界面设计如下:
业务逻辑分析
主程序调用业务逻辑层BLL,BLL使用抽象工厂DALFactory方法,DALFactory创建DAO实例对象,接口层IDAL定义数据操作接口方法,由数据访问层通过各自的公用数据操作类库进行读写数据库,实现对实体类Model的访问。
解决方案文件列表如图
其中DBUtility为公共数据访问类库。三个数据访问层SQLServerDAL、SqliteDAL和OleDAL分别对应Sql Server、Sqlite、Access数据库。这里我正在使用的是SqliteDAL。
具体实现
建立实体类进行对象封装
App.config定义选用的DAL及数据库连接信息
public class list
{
private int id;
/// <summary>
/// 编号
/// </summary>
public int Id
{
get { return id; }
set { id = value; }
}
private string num;
/// <summary>
/// 号码段(手机号前7位)
/// </summary>
public string Num
{
get { return num; }
set { num = value; }
}
private string code;
/// <summary>
/// 邮政编码
/// </summary>
public string Code
{
get { return code; }
set { code = value; }
}
private string city;
/// <summary>
///