- 浏览: 696086 次
- 性别:
- 来自: 福建
文章分类
最新评论
-
羽翼的心动:
同意2楼的说法,我们公司之前一个项目用过pageoffice, ...
poi导出excel文件工具类 -
贝塔ZQ:
poi实现导出excel文件,蛮麻烦的,用pageoffice ...
poi导出excel文件工具类 -
aishiqiang:
为什么我的项目配置好证书后,每次使用jenkinst自动构建包 ...
关于使用https协议,cas认证PKIX path building failed错误解决方法 -
zhongmin2012:
谢谢分享,正在想看
AST解析java源文件相关jar包 -
mybestroy1108:
感谢分享!受益良多!
Jboss7 JMS demo
这是我设计的dao的类图,我想通过这样的设计(如下图),已经可以实现单一dao的功能。
评论
8 楼
inroroc
2009-07-08
发到我邮箱即可,再次万分感谢
inroroc@163.com
inroroc@163.com
7 楼
inroroc
2009-07-08
能否将代码共享一下?万分感谢...
6 楼
lym6520
2009-07-08
show一下AbstractBaseDao的代码:
import java.io.Serializable; import java.util.Collection; import java.util.List; import org.hibernate.type.Type; import org.springframework.dao.DataAccessException; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import cn.f3.db.entity.AbstractHandleObj; /** * 基础Dao接口,定义通用的操作 * @author 08374 * @version v2.4 2009/07/07 * */ public abstract class AbstractBaseDao extends HibernateDaoSupport { /*对返回list进行定义,返回记录数,0不起作用*/ private int top = 0; public int getTop() { return top; } public void setTop(int top) { this.top = top; } /** * 对于返回列表的方法,通过调用我来实现返回记录数的控制, * 设置返回记录数,如若top为0不设置,使用完将top归0 */ protected void setMaxResult() throws DataAccessException{ if(this.getTop() > 0){ getHibernateTemplate().setMaxResults(this.getTop()); this.setTop(0); } } /** * 保存AbstractHandleObj实体 * @param hobj 继承AbstractHandleObj抽象类的实体 * @return Serializable 主键 */ public abstract Serializable save(AbstractHandleObj hobj) throws DataAccessException; /** * 更新AbstractHandleObj实体 * @param hobj 继承AbstractHandleObj抽象类的实体 * @return */ public abstract void update(AbstractHandleObj hobj) throws DataAccessException; /** * 保存或更新AbstractHandleObj实体 * @param hobj 继承AbstractHandleObj抽象类的实体 */ public abstract void saveOrUpdate(AbstractHandleObj hobj) throws DataAccessException; /** * 保存或跟新实体集合Collection<AbstractHandleObj> * 若实体已经存(根据主键判断)在则更新实体,则保存实体 * @param hobjList 继承AbstractHandleObj抽象类的实体集合 */ public abstract void saveOrUpdateAll(Collection<AbstractHandleObj> hobjList) throws DataAccessException; /** * 删除AbstractHandleObj实体 * @param hobj 继承AbstractHandleObj抽象类的实体 * @return */ public abstract void delete(AbstractHandleObj hobj) throws DataAccessException; /** * 删除Collection<AbstractHandleObj>集合实体 * @param hobjList 继承AbstractHandleObj抽象类的实体集合 */ public abstract void deleteAll(Collection<AbstractHandleObj> hobjList) throws DataAccessException; /** * 根据主键值获得继承AbstractHandleObj的实体 * @param entityName 继承AbstractHandleObj抽象类的实体名称(注:包含包名) * @param id 实体主键 * @return */ public abstract AbstractHandleObj findByID(String entityName, String id) throws DataAccessException; /**略...*/ }
5 楼
kunee
2009-07-08
标题党。。。。
4 楼
lym6520
2009-07-08
我这个是基于Hibernate实现的
3 楼
zhangde
2009-07-08
package com.market.b2c.suport.util.dao;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
/**
* 属性查找器
* author: zhangde
* date: Jul 5, 2009
*/
public class PropertyFinder implements Finder {
private Class cls;
private Map<String,Object> parameters;
private Map<String,Short> comparators;
public PropertyFinder(Class cls){
this.cls=cls;
}
public void addParameter(String name,Object value){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
}
public void addParameter(String name,Object value,short comparator){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
comparators.put(name, new Short(comparator));
}
@Override
public Map<String,Object> getParameters() {
return parameters;
}
@Override
public String getSql() {
StringBuffer sql=new StringBuffer("select * from ").append(cls.getSimpleName()).append(" where 1=1");
Iterator iterator=parameters.keySet().iterator();
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
Short comparator=null;
if(comparators!=null)
comparator=comparators.get(propertyName);
sql.append(" and ").append(propertyName).append(conversionComparator(comparator)).append(" ? ");
}
return sql.toString();
}
private String conversionComparator(Short comparator){
if(comparator==null || comparator==Finder.EQ)
return " = ";
if(comparator.shortValue()==Finder.GT)
return " > ";
if(comparator.shortValue()==Finder.LS)
return " < ";
return null;
}
@Override
public Class getCls() {
return cls;
}
}
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
/**
* 属性查找器
* author: zhangde
* date: Jul 5, 2009
*/
public class PropertyFinder implements Finder {
private Class cls;
private Map<String,Object> parameters;
private Map<String,Short> comparators;
public PropertyFinder(Class cls){
this.cls=cls;
}
public void addParameter(String name,Object value){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
}
public void addParameter(String name,Object value,short comparator){
if(parameters==null)
parameters=new HashMap();
parameters.put(name, value);
comparators.put(name, new Short(comparator));
}
@Override
public Map<String,Object> getParameters() {
return parameters;
}
@Override
public String getSql() {
StringBuffer sql=new StringBuffer("select * from ").append(cls.getSimpleName()).append(" where 1=1");
Iterator iterator=parameters.keySet().iterator();
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
Short comparator=null;
if(comparators!=null)
comparator=comparators.get(propertyName);
sql.append(" and ").append(propertyName).append(conversionComparator(comparator)).append(" ? ");
}
return sql.toString();
}
private String conversionComparator(Short comparator){
if(comparator==null || comparator==Finder.EQ)
return " = ";
if(comparator.shortValue()==Finder.GT)
return " > ";
if(comparator.shortValue()==Finder.LS)
return " < ";
return null;
}
@Override
public Class getCls() {
return cls;
}
}
2 楼
zhangde
2009-07-08
基于JDBC实现的
1 楼
zhangde
2009-07-08
发个我写的通用Dao 交流下
package com.market.b2c.suport.util.dao;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import com.market.b2c.domain.commodity.Commodity;
import com.market.b2c.suport.db.DBFactory;
/**
* description
* author: zhangde
* date: Jul 3, 2009
*/
public class BaseDaoJdbcImpl implements BaseDao {
private Connection conn;
private PreparedStatement ps;
private ResultSet rs;
public void save(Object object) {
StringBuffer sql = new StringBuffer("insert into ").append(object
.getClass().getSimpleName().toLowerCase());// 表名对应类名
sql.append(" (");
Field[] fields = object.getClass().getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
sql.append(fields[i].getName()).append(",");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(") values (");
for (int i = 0; i < fields.length; i++) {
sql.append("?,");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
System.out.println(sql.toString());
conn = DBFactory.getConnection();
try {
ps = conn.prepareStatement(sql.toString());
for (int i = 0; i < fields.length; i++) {
Object value = null;
String methodName = "get"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Method method = object.getClass().getMethod(methodName, null);
value = method.invoke(object, null);
ps.setObject(i + 1, value);
}
ps.execute();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
// Commodity commodity = new Commodity();
// //commodity.setId(new Integer(2));
// commodity.setName("commodity1");
BaseDao baseDao = new BaseDaoJdbcImpl();
// baseDao.save(commodity);
//
// Commodity commdoity2=(Commodity) baseDao.get(Commodity.class, new Integer(2));
// System.out.println(commdoity2.getName());
// System.out.println(commdoity2.getId());
//baseDao.delete(Commodity.class, new Integer(2));
// Commodity commodity=(Commodity) baseDao.getByProperty(Commodity.class, "name", "commodity1");
// System.out.println(commodity.getName());
// System.out.println(commodity.getId());
// List list=baseDao.findByProperty(Commodity.class, "name", "commodity1");
// System.out.println(list.size());
PropertyFinder finder=new PropertyFinder(Commodity.class);
finder.addParameter("name", "commodity1");
finder.addParameter("id", new Integer(30));
List list=baseDao.find(finder);
System.out.println(list.size());
}
public Object get(Class cls,Integer id) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String field=fields[i].getName();
String methodName="set"+ field.substring(0, 1).toUpperCase()+ field.substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(rs.findColumn(field))});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}
public void delete(Class cls, Integer id) {
String sql="delete from " + cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
try{
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
int row=ps.executeUpdate();
System.out.println(sql);
if(row==0)
throw new Exception("删除的行为0!");
}catch(Exception e){
e.printStackTrace();
}
}
public Object getByProperty(Class cls, String propertyName, Object value) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}
public List findByProperty(Class cls, String propertyName, Object value) {
List result=null;
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
@Override
public List find(Finder finder) {
List result=null;
conn = DBFactory.getConnection();
Field[] fields = finder.getCls().getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(finder.getSql());
Map parameters=finder.getParameters();
Iterator iterator=parameters.keySet().iterator();
int k=1;
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
ps.setObject(k++, parameters.get(propertyName));
System.out.println( parameters.get(propertyName));
}
System.out.println(finder.getSql());
rs=ps.executeQuery();
while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(finder.getCls().getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=finder.getCls().getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
package com.market.b2c.suport.util.dao;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import com.market.b2c.domain.commodity.Commodity;
import com.market.b2c.suport.db.DBFactory;
/**
* description
* author: zhangde
* date: Jul 3, 2009
*/
public class BaseDaoJdbcImpl implements BaseDao {
private Connection conn;
private PreparedStatement ps;
private ResultSet rs;
public void save(Object object) {
StringBuffer sql = new StringBuffer("insert into ").append(object
.getClass().getSimpleName().toLowerCase());// 表名对应类名
sql.append(" (");
Field[] fields = object.getClass().getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
sql.append(fields[i].getName()).append(",");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(") values (");
for (int i = 0; i < fields.length; i++) {
sql.append("?,");
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
System.out.println(sql.toString());
conn = DBFactory.getConnection();
try {
ps = conn.prepareStatement(sql.toString());
for (int i = 0; i < fields.length; i++) {
Object value = null;
String methodName = "get"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Method method = object.getClass().getMethod(methodName, null);
value = method.invoke(object, null);
ps.setObject(i + 1, value);
}
ps.execute();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
// Commodity commodity = new Commodity();
// //commodity.setId(new Integer(2));
// commodity.setName("commodity1");
BaseDao baseDao = new BaseDaoJdbcImpl();
// baseDao.save(commodity);
//
// Commodity commdoity2=(Commodity) baseDao.get(Commodity.class, new Integer(2));
// System.out.println(commdoity2.getName());
// System.out.println(commdoity2.getId());
//baseDao.delete(Commodity.class, new Integer(2));
// Commodity commodity=(Commodity) baseDao.getByProperty(Commodity.class, "name", "commodity1");
// System.out.println(commodity.getName());
// System.out.println(commodity.getId());
// List list=baseDao.findByProperty(Commodity.class, "name", "commodity1");
// System.out.println(list.size());
PropertyFinder finder=new PropertyFinder(Commodity.class);
finder.addParameter("name", "commodity1");
finder.addParameter("id", new Integer(30));
List list=baseDao.find(finder);
System.out.println(list.size());
}
public Object get(Class cls,Integer id) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String field=fields[i].getName();
String methodName="set"+ field.substring(0, 1).toUpperCase()+ field.substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(rs.findColumn(field))});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}
public void delete(Class cls, Integer id) {
String sql="delete from " + cls.getSimpleName().toLowerCase()+" where id=?";
conn = DBFactory.getConnection();
try{
ps = conn.prepareStatement(sql.toString());
ps.setInt(1, id.intValue());
int row=ps.executeUpdate();
System.out.println(sql);
if(row==0)
throw new Exception("删除的行为0!");
}catch(Exception e){
e.printStackTrace();
}
}
public Object getByProperty(Class cls, String propertyName, Object value) {
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(object!=null)
throw new Exception("主键不唯一!");
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
}
} catch (Exception e) {
e.printStackTrace();
}
return object;
}
public List findByProperty(Class cls, String propertyName, Object value) {
List result=null;
String sql="select * from "+cls.getSimpleName().toLowerCase()+" where "+propertyName+"=?";
conn = DBFactory.getConnection();
Field[] fields = cls.getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(sql.toString());
ps.setObject(1, value);
rs=ps.executeQuery();
System.out.println(sql);
while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(cls.getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=cls.getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
@Override
public List find(Finder finder) {
List result=null;
conn = DBFactory.getConnection();
Field[] fields = finder.getCls().getDeclaredFields();
Object object=null;
try {
ps = conn.prepareStatement(finder.getSql());
Map parameters=finder.getParameters();
Iterator iterator=parameters.keySet().iterator();
int k=1;
while(iterator.hasNext()){
String propertyName=(String) iterator.next();
ps.setObject(k++, parameters.get(propertyName));
System.out.println( parameters.get(propertyName));
}
System.out.println(finder.getSql());
rs=ps.executeQuery();
while(rs.next()){
if(result==null)
result=new ArrayList();
Class clstmp=Class.forName(finder.getCls().getName());
object=clstmp.newInstance();
//组装参数
for(int i=0;i<fields.length;i++){
String methodName="set"+ fields[i].getName().substring(0, 1).toUpperCase()+ fields[i].getName().substring(1);
Class[] classs=new Class[1];
classs[0]=fields[i].getType();
Method method=finder.getCls().getMethod(methodName,classs);
method.invoke(object, new Object[]{rs.getObject(i+1)});
}
result.add(object);
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
发表评论
-
系统权限模块设计(ps:有图有真相!)
2011-01-22 21:46 8801在百度百科里查到 ... -
设计模式 之 “门面模式[Facade Pattern]”
2010-07-07 08:48 1223门面模式[Facade Pattern]类图 门面模式[F ... -
设计模式 之 “抽象工厂模式[Abstract Factory Pattern]”
2010-06-29 15:21 1091抽象工厂模式[Abstract Factory Pattern ... -
设计模式之“工厂方法模式[Factory Method Pattern]”
2010-06-24 08:30 1012工厂方法模式[Factory Method Pattern]类 ... -
设计模式 之 “单例模式[Singleton Pattern]”
2010-06-21 08:56 1377单例模式[Singleton Pattern]类图 这里我 ... -
设计模式 之 “代理模式[Proxy Pattern]”
2010-06-17 10:29 1345闲话不多说,今天就看看代理模式吧! 代理模式[Proxy P ... -
设计模式 之 “策略模式[Strategy Pattern]”
2010-06-12 14:43 1584到doone上班有半个月了,在一个新的环境里很多时候我 ... -
集思广益,这样的设计可行吗?
2009-07-11 14:36 1450希望大家可以帮我解答下这个问题,如下图所示,为了实现一个通用d ... -
我的万能dao 设计源码,请大家多多指教!
2009-07-09 10:07 4260首先,先看下类图:(在这篇文章已经发过了http://lym6 ...
相关推荐
DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式DAO设计模式
DAO设计模式 DAO 设计模式 JAVA设计模
实现利用Timer倒计时,调整Interval可调整分钟或小时
1)dao类的繁多,很多设计都是一个entity对应一个dao (不同的只有类名和方法名) 2)dao接口需要维护的method庞大。 3)业务逻辑改变时,dao需要同时修改两个类文件(接口和实现类) 在本文中,我将为您展示如何...
本教程主要介绍了Dao设计模式,并且还有一些实例
李兴华DAO设计模式
暴露给客户端的DAO接口在低层数据源的实现发生改变时并不会随着改变,所以这种设计模式使得DAO可以适应不同的数据储存方式类型而不影响客户端和商业组件.最主要的, DAO还在组件和数据源之间扮演着协调者的角色. DAO...
DAO设计模式是属于J2EE数据层的操作,使用DAO设计模式可以简化大量代码,增强程序的可移植性。
DAO设计模式
基于DAO设计模式的新闻发布系统基于DAO设计模式的新闻发布系统基于DAO设计模式的新闻发布系统基于DAO设计模式的新闻发布系统基于DAO设计模式的新闻发布系统
DAO设计模式DAO设计模式,网上多份精华讲解汇总!
JSP中DAO设计模式中用户的插入与查询操作。
java,dao设计模式,主要介绍Dao三层架构的设计模式,让我们更加深入理解Java 框架。
用简单易懂的例子说明DAO设计模式(附带sql脚本,mysql数据库)
DAO模式实现增加删除修改操作.rar
设计分层DAO程序设计的相关知识
JSP留言管理系统Ⅵ(MVC+DAO设计模式),分享大家共同学习!
DAO(Data Access Object)是一个数据访问接口,数据访问:顾名思义就是与数据库打交道。夹在业务逻辑与数据库资源中间。 本文按照DAO设计模式的思想,设计并实现了该模式架构。
dao设计模式 对初学者很有帮助
DAO 设计模式经典实例