比如我用代码生成器生成了一个UnitInfoEntity.java的实体类,同时生成了UnitInfoController.java的控制类,在改类中用到unitInfoService进行数据的增删改查,
unitInfoService的声明方式是这个样的:
@Autowired
private UnitInfoServiceI unitInfoService;
查看UnitInfoServiceI接口,代码如下:
package jeecg.gwc.db.service.unitinfo;
import org.jeecgframework.core.common.service.CommonService;
public interface UnitInfoServiceI extends CommonService{
}
并没有任何方法的声明。
再看一下UnitInfoServiceI实现类UnitInfoServiceImpl的代码:
package jeecg.gwc.db.service.impl.unitinfo;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import jeecg.gwc.db.service.unitinfo.UnitInfoServiceI;
import org.jeecgframework.core.common.service.impl.CommonServiceImpl;
@Service("unitInfoService")
@Transactional
public class UnitInfoServiceImpl extends CommonServiceImpl implements UnitInfoServiceI {
}
可以看到该类继承了CommonServiceImpl(org.jeecgframework.core.common.service.impl.)类,实现了UnitInfoServiceI(jeecg.gwc.db.service.unitinfo.)接口
可以看到该类上方有个注解:@Service("unitInfoService") 括号里的名称跟Controller中service的变量名称一致。所以应该是Spring将UnitInfoServiceImpl的对象注入到Controller类。
也就是用了UnitInfoServiceImpl的对象。
那么这个对象中有什么具体的方法吗?
就要看继承的CommonServiceImpl有哪些方法了。
看下CommonServiceImpl的具体源码:
package org.jeecgframework.core.common.service.impl;
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import jeecg.system.pojo.base.TSDepart;
import org.hibernate.Session;
import org.jeecgframework.core.common.dao.ICommonDao;
import org.jeecgframework.core.common.hibernate.qbc.CriteriaQuery;
import org.jeecgframework.core.common.hibernate.qbc.HqlQuery;
import org.jeecgframework.core.common.hibernate.qbc.PageList;
import org.jeecgframework.core.common.model.common.DBTable;
import org.jeecgframework.core.common.model.common.UploadFile;
import org.jeecgframework.core.common.model.json.ComboTree;
import org.jeecgframework.core.common.model.json.DataGridReturn;
import org.jeecgframework.core.common.model.json.ImportFile;
import org.jeecgframework.core.common.model.json.TreeGrid;
import org.jeecgframework.core.common.service.CommonService;
import org.jeecgframework.tag.vo.datatable.DataTableReturn;
import org.jeecgframework.tag.vo.easyui.Autocomplete;
import org.jeecgframework.tag.vo.easyui.ComboTreeModel;
import org.jeecgframework.tag.vo.easyui.TreeGridModel;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service("commonService")
@Transactional
public class CommonServiceImpl implements CommonService {
public ICommonDao commonDao = null;
/**
* 获取所有数据库表
* @return
*/
public List<DBTable> getAllDbTableName()
{
return commonDao.getAllDbTableName();
}
public Integer getAllDbTableSize() {
return commonDao.getAllDbTableSize();
}
@Resource
public void setCommonDao(ICommonDao commonDao) {
this.commonDao = commonDao;
}
@Override
public <T> void save(T entity) {
commonDao.save(entity);
}
@Override
public <T> void saveOrUpdate(T entity) {
commonDao.saveOrUpdate(entity);
}
@Override
public <T> void delete(T entity) {
commonDao.delete(entity);
}
/**
* 删除实体集合
*
* @param <T>
* @param entities
*/
public <T> void deleteAllEntitie(Collection<T> entities) {
commonDao.deleteAllEntitie(entities);
}
/**
* 根据实体名获取对象
*/
public <T> T get(Class<T> class1, Serializable id) {
return commonDao.get(class1, id);
}
/**
* 根据实体名返回全部对象
*
* @param <T>
* @param hql
* @param size
* @return
*/
public <T> List<T> getList(Class clas) {
return commonDao.loadAll(clas);
}
/**
* 根据实体名获取对象
*/
public <T> T getEntity(Class entityName, Serializable id) {
return commonDao.getEntity(entityName, id);
}
/**
* 根据实体名称和字段名称和字段值获取唯一记录
*
* @param <T>
* @param entityClass
* @param propertyName
* @param value
* @return
*/
public <T> T findUniqueByProperty(Class<T> entityClass, String propertyName, Object value) {
return commonDao.findUniqueByProperty(entityClass, propertyName, value);
}
/**
* 按属性查找对象列表.
*/
public <T> List<T> findByProperty(Class<T> entityClass, String propertyName, Object value) {
return commonDao.findByProperty(entityClass, propertyName, value);
}
/**
* 加载全部实体
*
* @param <T>
* @param entityClass
* @return
*/
public <T> List<T> loadAll(final Class<T> entityClass) {
return commonDao.loadAll(entityClass);
}
public <T> T singleResult(String hql)
{
return commonDao.singleResult(hql);
}
/**
* 删除实体主键ID删除对象
*
* @param <T>
* @param entities
*/
public <T> void deleteEntityById(Class entityName, Serializable id) {
commonDao.deleteEntityById(entityName, id);
}
/**
* 更新指定的实体
*
* @param <T>
* @param pojo
*/
public <T> void updateEntitie(T pojo) {
commonDao.updateEntitie(pojo);
}
/**
* 通过hql 查询语句查找对象
*
* @param <T>
* @param query
* @return
*/
public <T> List<T> findByQueryString(String hql) {
return commonDao.findByQueryString(hql);
}
/**
* 根据sql更新
*
* @param query
* @return
*/
public int updateBySqlString(String sql) {
return commonDao.updateBySqlString(sql);
}
/**
* 根据sql查找List
*
* @param <T>
* @param query
* @return
*/
public <T> List<T> findListbySql(String query) {
return commonDao.findListbySql(query);
}
/**
* 通过属性称获取实体带排序
*
* @param <T>
* @param clas
* @return
*/
public <T> List<T> findByPropertyisOrder(Class<T> entityClass, String propertyName, Object value, boolean isAsc) {
return commonDao.findByPropertyisOrder(entityClass, propertyName, value, isAsc);
}
/**
*
* cq方式分页
*
* @param cq
* @param isOffset
* @return
*/
public PageList getPageList(final CriteriaQuery cq, final boolean isOffset) {
return commonDao.getPageList(cq, isOffset);
}
/**
* 返回DataTableReturn模型
*
* @param cq
* @param isOffset
* @return
*/
public DataTableReturn getDataTableReturn(final CriteriaQuery cq, final boolean isOffset) {
return commonDao.getDataTableReturn(cq, isOffset);
}
/**
* 返回easyui datagrid模型
*
* @param cq
* @param isOffset
* @return
*/
public DataGridReturn getDataGridReturn(final CriteriaQuery cq, final boolean isOffset) {
return commonDao.getDataGridReturn(cq, isOffset);
}
/**
*
* hqlQuery方式分页
*
* @param cq
* @param isOffset
* @return
*/
public PageList getPageList(final HqlQuery hqlQuery, final boolean needParameter) {
return commonDao.getPageList(hqlQuery, needParameter);
}
/**
*
* sqlQuery方式分页
*
* @param cq
* @param isOffset
* @return
*/
public PageList getPageListBySql(final HqlQuery hqlQuery, final boolean isToEntity) {
return commonDao.getPageListBySql(hqlQuery, isToEntity);
}
public Session getSession()
{
return commonDao.getSession();
}
public List findByExample(final String entityName, final Object exampleEntity) {
return commonDao.findByExample(entityName, exampleEntity);
}
/**
* 通过cq获取全部实体
*
* @param <T>
* @param cq
* @return
*/
public <T> List<T> getListByCriteriaQuery(final CriteriaQuery cq,Boolean ispage) {
return commonDao.getListByCriteriaQuery(cq,ispage);
}
/**
* 文件上传
*
* @param request
*/
public <T> T uploadFile(UploadFile uploadFile) {
return commonDao.uploadFile(uploadFile);
}
public HttpServletResponse viewOrDownloadFile(UploadFile uploadFile)
{
return commonDao.viewOrDownloadFile(uploadFile);
}
/**
* 生成XML文件
*
* @param fileName
* XML全路径
* @return
*/
public HttpServletResponse createXml(ImportFile importFile) {
return commonDao.createXml(importFile);
}
/**
* 解析XML文件
*
* @param fileName
* XML全路径
*/
public void parserXml(String fileName) {
commonDao.parserXml(fileName);
}
public List<ComboTree> comTree(List<TSDepart> all, ComboTree comboTree) {
return commonDao.comTree(all, comboTree);
}
/**
* 根据模型生成JSON
*
* @param all
* 全部对象
* @param in
* 已拥有的对象
* @param comboBox
* 模型
* @return
*/
public List<ComboTree> ComboTree(List all,ComboTreeModel comboTreeModel,List in) {
return commonDao.ComboTree(all,comboTreeModel,in);
}
/**
* 构建树形数据表
*/
public List<TreeGrid> treegrid(List all, TreeGridModel treeGridModel) {
return commonDao.treegrid(all, treeGridModel);
}
/**
* 获取自动完成列表
*
* @param <T>
* @return
*/
public <T> List<T> getAutoList(Autocomplete autocomplete) {
StringBuffer sb = new StringBuffer("");
for(String searchField:autocomplete.getSearchField().split(",")){
sb.append(" or "+searchField+" like '%"+autocomplete.getTrem() + "%' ");
}
String hql = "from " + autocomplete.getEntityName() + " where 1!=1 " + sb.toString();
return commonDao.getSession().createQuery(hql).setFirstResult(autocomplete.getCurPage()-1).setMaxResults(autocomplete.getMaxRows()).list();
}
@Override
public Integer executeSql(String sql, List<Object> param) {
return commonDao.executeSql(sql, param);
}
@Override
public Integer executeSql(String sql, Object... param) {
return commonDao.executeSql(sql, param);
}
@Override
public Integer executeSql(String sql, Map<String, Object> param) {
return commonDao.executeSql(sql, param);
}
@Override
public List<Map<String, Object>> findForJdbc(String sql, int page, int rows) {
return commonDao.findForJdbc(sql, page,rows);
}
@Override
public List<Map<String, Object>> findForJdbc(String sql, Object... objs) {
return commonDao.findForJdbc(sql, objs);
}
@Override
public List<Map<String, Object>> findForJdbcParam(String sql, int page,
int rows, Object... objs) {
return commonDao.findForJdbcParam(sql, page, rows, objs);
}
@Override
public <T> List<T> findObjForJdbc(String sql, int page, int rows,
Class<T> clazz) {
return commonDao.findObjForJdbc(sql, page, rows, clazz);
}
@Override
public Map<String, Object> findOneForJdbc(String sql, Object... objs) {
return commonDao.findOneForJdbc(sql, objs);
}
@Override
public Long getCountForJdbc(String sql) {
return commonDao.getCountForJdbc(sql);
}
@Override
public Long getCountForJdbcParam(String sql, Object[] objs) {
return commonDao.getCountForJdbc(sql);
}
@Override
public <T> void batchSave(List<T> entitys) {
this.commonDao.batchSave(entitys);
}
/**
* 通过hql 查询语句查找对象
*
* @param <T>
* @param query
* @return
*/
public <T> List<T> findHql(String hql, Object... param) {
return this.commonDao.findHql(hql, param);
}
}
该类是实现了CommonService接口,该接口中就声明了各种数据操作方法。但是在该实现类中用到了具体的Dao操作数据库。看一下这个Dao的具体实现是什么样的。
org.jeecgframework.core.common.dao.ICommonDao
这是一个 接口
commonDao是一个接口变量。
他的实现类:org.jeecgframework.core.common.dao.impl.CommonDao
代码:
@Repository
public class CommonDao extends GenericBaseCommonDao implements ICommonDao, IGenericBaseCommonDao {
可以看到,CommonDao还继承 了GenericBaseCommonDao,操作数据的方法就在GenericBaseCommonDao中,
GenericBaseCommonDao类是一个抽象类
@SuppressWarnings("hiding")
public abstract class GenericBaseCommonDao<T, PK extends Serializable> implements IGenericBaseCommonDao {
反正是关于数据库操作的都在GenericBaseCommonDao类里