数据库持久层设计接口IDesignTimeDAO
该接口主要定义如下几个方法:查询、新增、修改等。
本接口采用了泛型作为入参。什么是泛型
泛型,即“参数化类型”。一提到参数,最熟悉的就是定义方法时有形参,然后调用此方法时传递实参。那么参数化类型怎么理解呢?顾名思义,就是将类型由原来的具体的类型参数化,类似于方法中的变量参数,此时类型也定义成参数形式(可以称之为类型形参),然后在使用/调用时传入具体的类型(类型实参)。
为了增加通用性,因为数据库操作对象不是一个,而是多个,因此采用泛型入参。<E>中的E表示类型形参,可以接收具体的类型实参,并且此接口定义中,凡是出现E的地方均表示相同的接受自外部的类型实参。
通过传递hql或sql语句进行操作。返回的集合Collection。
1、遵循接口一旦被实现(implements),接口内的方法必须全部实现,但是当实现类为抽象类时,接口内的方法可以不实现或者部分实现;
2、在实现代码重用性,又特此定义了 部分抽象类。但是均implements当前接口。
3、方法中采用collection:概念
可以通过迭代器获取数据
//获取迭代器,并用迭代器迭代元素。
for(Iterator it = coll.iterator();it.hasNext();){
System.out.println(it.next());
}
具体代码如下:
public interface IDesignTimeDAO<E> extends IBaseDAO {
public abstract Object getData(String hql) throws Exception;
public abstract Collection<E> getDatas(String hql) throws Exception;
public abstract Collection<E> getDatas(String hql, ParamsTable params) throws Exception;
public abstract Collection<E> getDatas(String hql, ParamsTable params, int page, int lines) throws Exception;
public abstract int getTotalLines(String hql) throws Exception;
public abstract Collection<E> getDatas(String hql, int page, int lines) throws Exception;
public abstract DataPackage<E> getDatapackage(String hql) throws Exception;
public abstract DataPackage<E> getDatapackage(String hql, int page, int lines) throws Exception;
public abstract DataPackage<E> getDatapackage(String hql, ParamsTable params) throws Exception;
public abstract DataPackage<E> getDatapackage(String hql, ParamsTable params, int page, int lines) throws Exception;//分页查询
public abstract void create(ValueObject vo, WebUser user) throws Exception;//创建对象
public abstract void create(Object po) throws Exception;
public abstract void update(ValueObject vo, WebUser user) throws Exception;//更新数据
public abstract void update(Object po) throws Exception;//更新数据对象
public abstract DataPackage<E> query(ParamsTable params) throws Exception;
public abstract SessionFactory buildSessionFactory() throws Exception;
public abstract ValueObject find(String id) throws Exception;
public abstract ValueObject findByName(String name, String application) throws Exception;
public abstract void create(ValueObject vo) throws Exception;
public abstract void update(ValueObject vo) throws Exception;
public abstract void remove(String id) throws Exception;
public abstract void remove(ValueObject obj) throws Exception;
public abstract void remove(String ids[]) throws Exception;
public abstract void remove(Collection<E> vos) throws Exception;
public abstract DataPackage<E> query(ParamsTable params, WebUser user) throws Exception;
public abstract Collection<E> simpleQuery(ParamsTable params) throws Exception;
public DataPackage<E> getDatapackageBySQL(String sql, ParamsTable params, int page, int lines) throws Exception;
public String getSchema();//获取数据库的用户,例如oracle中用户。
public Collection<E> getDatasBySQL(String sql, int page, int lines) throws Exception;
public Collection<E> getDatasBySQL(String sql) throws Exception;
public Collection<E> queryByHQL(String hql,int pageNo,int pageSize) throws Exception;
public int executeUpdate(String hql) throws Exception;
public void checkout(String id, WebUser user) throws Exception;
public void checkin(String id, WebUser user) throws Exception;
public List queryBySql(String sql) throws Exception;
}