【Java 新建项目】使用程序对新项目的各个实体 创建Dao、DaoImpl、Service、ServiceImpl层的文件

简介: 优化之后的步骤:1.第一步 生成各层文件夹,并且创建GenericDao.java等基础dao【基础dao中涉及到的包名等自行更改】2.第二步 生成各个实体对应的Dao等层文件  首先给出基本Dao层代码:【将这些类保存为文件,放在固定的位置】GenericDao.

优化之后的步骤:

1.第一步 生成各层文件夹,并且创建GenericDao.java等基础dao【基础dao中涉及到的包名等自行更改】

2.第二步 生成各个实体对应的Dao等层文件

 

 

首先给出基本Dao层代码:【将这些类保存为文件,放在固定的位置】

GenericDao.java

  1 package com.agen.dao;
  2 
  3 import java.io.Serializable;
  4 import java.util.Collection;
  5 import java.util.List;
  6 import java.util.Map;
  7 
  8 import org.hibernate.Criteria;
  9 import org.hibernate.criterion.Criterion;
 10 import org.hibernate.criterion.DetachedCriteria;
 11 
 12 import com.github.pagehelper.PageInfo;
 13 
 14 
 15 public interface GenericDao<T, PK extends Serializable> {
 16     /**
 17      * 查询全部,可以排序
 18      * @param orderBy
 19      * @param isAsc
 20      * @return List<T>
 21      */
 22     public List<T> list(Criteria criteria);
 23 
 24     /**
 25      * 查询全部,可以排序
 26      * @param orderBy
 27      * @param isAsc
 28      * @return List<T>
 29      */
 30     public List<T> list(String orderBy, boolean isAsc);
 31     
 32     /**
 33      * 离线查询
 34      * @param criteria
 35      * @return List<T>
 36      */
 37     public List<T> list(DetachedCriteria criteria);
 38     
 39     /**
 40      * 根据Criteria查询条件,获取总数
 41      * @param criteria
 42      * @return int
 43      * @throws SecurityException 
 44      * @throws NoSuchFieldException 
 45      * @throws IllegalAccessException 
 46      * @throws IllegalArgumentException 
 47      */
 48     public int countAll(Criteria criteria);
 49     
 50     /**
 51      * 获取总数(默认为entityClass) 即查询总条数
 52      * @return int
 53      */
 54     public int countAll();
 55     
 56     /**
 57      * 根据I判断是否存在
 58      * @param id
 59      * @return boolean
 60      */
 61     public boolean exists(PK id);
 62     
 63     /**
 64      * 保存实体 
 65      * @param t 实体参数
 66      */
 67     public void save(T t);
 68 
 69     /**
 70      * 保存或者更新实体
 71      * @param t 实体
 72      */
 73     public void saveOrUpdate(T t);
 74 
 75     /**
 76      * 加载实体的通过load方法
 77      * @param id 实体的id
 78      * @return 查询出来的实体
 79      */
 80     public T load(PK id);
 81     
 82     /**
 83      * 合并实体 
 84      * @param entity
 85      */
 86     public void merge(T entity);
 87     
 88     /**
 89      * 查找全部
 90      */
 91     public List<T> findAll();
 92 
 93     /**
 94      * 通过get方法加载实体的
 95      * @param id 实体的id
 96      * @return 查询出来的实体
 97      */
 98     public T get(PK id);
 99 
100     /**
101      * contains
102      * @param t 实体
103      * @return 是否包含
104      */
105     public boolean contains(T t);
106 
107     /**
108      * delete
109      * @param t
110      * 删除实体
111      */
112     public void delete(T t);
113 
114     /**
115      * 根据ID删除数据
116      * @param Id 实体id
117      * @return 是否删除成功
118      */
119     public boolean deleteById(PK Id);
120 
121     /**
122      * 删除所有
123      * @param entities 实体的Collection集合
124      */
125     public void deleteAll(Collection<T> entities);
126 
127     /**
128      * 执行Hql语句 要求 hql中参数顺序与可变参数 中参数顺序相一致
129      * @param hqlString hql
130      * @param values 不定参数数组
131      */
132     public void queryHql(String hqlString, Object... values);
133 
134     /**
135      * 执行Sql语句(不建议用,影响扩展)
136      * @param sqlString sql
137      * @param values 不定参数数组
138      */
139     public void querySql(String sqlString, Object... values);
140 
141     /**
142      * 根据HQL语句查找唯一实体
143      * 
144      * @param hqlString HQL语句
145      * @param values 不定参数的Object数组
146      * @return 查询实体
147      */
148     public T getByHQL(String hqlString, Object... values);
149     
150     /**
151      * 根据SQL语句查找唯一实体(不建议用,影响扩展)
152      * @param sqlString SQL语句
153      * @param values 不定参数的Object数组
154      * @return 查询实体
155      */
156 
157     /**
158      * 根据HQL语句,得到对应的list
159      * @param hqlString HQL语句
160      * @param values 不定参数的Object数组
161      * @return 查询多个实体的List集合
162      */
163     public List<T> getListByHQL(String hqlString, Object... values);
164 
165     /**
166      * 根据SQL语句,得到对应的list(不建议用,影响扩展)
167      * @param sqlString HQL语句
168      * @param values 不定参数的Object数组
169      * @return 查询多个实体的List集合
170      */
171     public List<T> getListBySQL(String sqlString, Object... values);
172 
173     /**
174      * refresh 刷新实体,强制与数据库两步 refresh方法应该是数据库的数据更新到本地的person实体中,而不是本地person更新数据到数据库中  也就是执行refresh方法是更新了java代码中变量的数据值
175      * @param t 实体
176      */
177     public void refresh(T t);
178 
179     /**
180      * update
181      * @param t
182      * 更新的是数据库中的数据
183      */
184     public void update(T t);
185 
186     /**
187      * 根据HQL得到记录数
188      * @param hql HQL语句
189      * @param values 不定参数的Object数组
190      * @return 记录总数
191      */
192     public Long countByHql(String hql, Object... values);
193 
194     /**
195      * HQL分页查询
196      * 
197      * @param hql HQL语句
198      * @param countHql 查询记录条数的HQL语句
199      * @param pageNo 下一页
200      * @param pageSize 一页总条数
201      * @param values  不定Object数组参数
202      * @return PageResults的封装类,里面包含了页码的信息以及查询的数据List集合
203      */
204     public  PageInfo<T> findPageByHql(String hql, String countHql, int pageNo, int pageSize, Object... values);
205     
206     /**
207      * 按属性查找对象列表,匹配方式为相等
208      * @param propertyName
209      * @param value
210      * @return List<T>
211      */
212     public List<T> list(String propertyName, Object value);
213     
214     /**
215      * 根据criterion查询条件获取数据列表
216      * @param criterion
217      * @return List<T>
218      */
219     public List<T> list(Criterion criterion);
220     
221     /**
222      * 按Criteria查询对象列表
223      * @param criterions
224      * @return List<T>
225      */
226     public List<T> list(Criterion... criterions);
227     
228     /**
229      * 按属性查找唯一对象,匹配方式为相等
230      * @param propertyName
231      * @param value
232      * @return T
233      */
234     public T uniqueResult(String propertyName, Object value);
235     
236     /**
237      * 按Criteria查询唯一对象
238      * @param criterions
239      * @return T
240      */
241     public T uniqueResult(Criterion... criterions);
242     
243     /**
244      * 按Criteria查询唯一对象
245      * @param criteria
246      * @return T
247      */
248     public T uniqueResult(Criteria criteria);
249     
250     /**
251      * 按criteria查询某个Integer类型的字段
252      * @param criteria
253      * @return
254      */
255     public Integer uniqueResultInt(Criteria criteria);
256     
257     /**
258      * 为Criteria添加distinct transformer
259      * @param criteria
260      * @return Criteria
261      */
262     public Criteria distinct(Criteria criteria);
263     
264     /**
265      * 刷新session
266      */
267     public void flush();
268     
269     /**
270      * 清空session
271      */
272     public void clear();
273     
274     /**
275      * 创建Criteria实例
276      */
277     public Criteria createCriteria();
278     
279     /**
280      * 根据Criterion条件创建Criteria
281      * @param criterions
282      * @return Criteria
283      */
284     public Criteria createCriteria(Criterion... criterions);
285     
286     /**
287      * 分页查询Criteria
288      * @param criteria 
289      * @param pageNo 下页页码
290      * @param pageSize 页面数据量
291      * @return List<T>
292      */
293     public List<T> findPage(Criteria criteria, int pageNo, int pageSize);
294     
295     /**
296      * 分页查询Criteria
297      * @param criteria
298      * @param pageNo
299      * @param pageSize
300      * @return PageInfo<T>
301      * @throws SecurityException 
302      * @throws NoSuchFieldException 
303      * @throws IllegalAccessException 
304      * @throws IllegalArgumentException 
305      */
306     public PageInfo<T> findQuery(Criteria criteria, int pageNo, int pageSize);
307     
308     /**
309      * 
310      * @param hql
311      * @param pageNo
312      * @param pageSize
313      * @param map
314      * @return List<T>
315      */
316     public List<T> findQuery(String hql, int pageNo, int pageSize, Map<?, ?> map);
317 }
View Code

GenericDaoImpl.java

  1 package com.agen.dao.impl;
  2 
  3 import java.io.Serializable;
  4 import java.lang.reflect.Field;
  5 import java.util.ArrayList;
  6 import java.util.Collection;
  7 import java.util.List;
  8 import java.util.Map;
  9 import java.util.Map.Entry;
 10 
 11 import org.hibernate.Criteria;
 12 import org.hibernate.Query;
 13 import org.hibernate.QueryException;
 14 import org.hibernate.ScrollableResults;
 15 import org.hibernate.Session;
 16 import org.hibernate.SessionFactory;
 17 import org.hibernate.criterion.CriteriaSpecification;
 18 import org.hibernate.criterion.Criterion;
 19 import org.hibernate.criterion.DetachedCriteria;
 20 import org.hibernate.criterion.Order;
 21 import org.hibernate.criterion.Projections;
 22 import org.hibernate.criterion.Restrictions;
 23 import org.hibernate.internal.CriteriaImpl;
 24 import org.hibernate.internal.CriteriaImpl.Subcriteria;
 25 import org.springframework.beans.factory.annotation.Autowired;
 26 import org.springframework.transaction.annotation.Transactional;
 27 import org.springframework.util.Assert;
 28 
 29 import java.lang.reflect.ParameterizedType; 
 30 
 31 import com.agen.dao.GenericDao;
 32 import com.github.pagehelper.PageInfo;
 33 
 34 public class GenericDaoImpl<T, PK extends Serializable> implements GenericDao<T, PK> {
 35     /**
 36      * 不建议直接使用
 37      */
 38     @Autowired
 39     private SessionFactory sessionFactory;
 40     
 41     public Session getSession() {
 42         // 需要开启事物,才能得到CurrentSession
 43         return sessionFactory.getCurrentSession();
 44     }
 45     
 46     
 47     protected Class<T> entityClass;
 48 
 49     protected Class getEntityClass() {
 50         if (entityClass == null) {
 51             if(((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments().length > 0) {
 52                 entityClass = (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
 53             }
 54         }
 55         return entityClass;
 56     }
 57 
 58     public SessionFactory getSessionFactory() {
 59         return sessionFactory;
 60     }
 61     
 62     public void setSessionFactory(SessionFactory sessionFactory) {
 63         this.sessionFactory = sessionFactory;
 64     }
 65     
 66     @Override
 67     public Criteria createCriteria() {
 68         return getSession().createCriteria(getEntityClass());
 69     }
 70 
 71     
 72     @Override
 73     public void save(T t) {
 74         this.getSession().save(t);
 75     }
 76 
 77     @Override
 78     public void saveOrUpdate(T t) {
 79         Assert.notNull(t);
 80         this.getSession().saveOrUpdate(t);
 81     }
 82     
 83     @Override
 84     public T load(PK id) {
 85         Assert.notNull(id);
 86         T load = (T) this.getSession().load(getEntityClass(), id);
 87         return load;
 88     }
 89 
 90     @Override
 91     public T get(PK id) {
 92         Assert.notNull(id);
 93         T load = (T) this.getSession().get(getEntityClass(), id);
 94         return load;
 95     }
 96 
 97     @Override
 98     public boolean contains(T t) {
 99         Assert.notNull(t);
100         return this.getSession().contains(t);
101     }
102 
103     @Override
104     public void delete(T t) {
105         Assert.notNull(t);
106         this.getSession().delete(t);
107     }
108 
109     @Override
110     public boolean deleteById(PK Id) {
111         Assert.notNull(Id);
112         T t = get(Id);
113         if (t == null) return false;
114         delete(t);
115         return true;
116     }
117 
118     @Override
119     public void deleteAll(Collection<T> entities) {
120         Assert.notNull(entities);
121         for (Object entity : entities) {
122             this.getSession().delete(entity);
123         }
124     }
125 
126     @Override
127     public void queryHql(String hqlString, Object... values) {
128         Query query = this.getSession().createQuery(hqlString);
129         if (values != null) {
130             for (int i = 0; i < values.length; i++) {
131                 query.setParameter(i, values[i]);
132             }
133         }
134         query.executeUpdate();
135     }
136     
137     /**
138      * 根据hql  和    map集合中的数据   进行相对应的 insert   update   delete操作
139      * @param hqlString
140      * @param paras
141      */
142     public void queryHql(String hqlString, Map<String, Object> paras) {
143         Query query = this.getSession().createQuery(hqlString);
144         if (paras != null) {
145             for (Entry<String, Object> en : paras.entrySet()) {
146                 query.setParameter(en.getKey(), en.getValue());
147             }
148         }
149         query.executeUpdate();
150     }
151 
152     @Override
153     public void querySql(String sqlString, Object... values) {
154         Query query = this.getSession().createSQLQuery(sqlString);
155         if (values != null) {
156             for (int i = 0; i < values.length; i++) {
157                 query.setParameter(i, values[i]);
158             }
159         }
160         query.executeUpdate();
161     }
162 
163     @Override
164     public T getByHQL(String hqlString, Object... values) {
165         Query query = this.getSession().createQuery(hqlString);
166         if (values != null) {
167             for (int i = 0; i < values.length; i++) {
168                 query.setParameter(i, values[i]);
169             }
170         }
171         return (T) query.uniqueResult();
172     }
173 
174     @Override
175     public List<T> getListByHQL(String hqlString, Object... values) {
176         Query query = this.getSession().createQuery(hqlString);
177         if (values != null) {
178             for (int i = 0; i < values.length; i++) {
179                 query.setParameter(i, values[i]);
180             }
181         }
182         return query.list();
183     }
184 
185     @Override
186     public List<T> getListBySQL(String sqlString, Object... values) {
187         Query query = this.getSession().createSQLQuery(sqlString);
188         if (values != null) {
189             for (int i = 0; i < values.length; i++) {
190                 query.setParameter(i, values[i]);
191             }
192         }
193         return query.list();
194     }
195 
196     @Override
197     public void refresh(T t) {
198         this.getSession().refresh(t);
199     }
200 
201     @Override
202     public void update(T t) {
203         this.getSession().update(t);
204     }
205 
206     @Override
207     public Long countByHql(String hql, Object... values) {
208         Query query = this.getSession().createQuery(hql);
209         if (values != null) {
210             for (int i = 0; i < values.length; i++) {
211                 query.setParameter(i, values[i]);
212             }
213         }
214         return (Long) query.uniqueResult();
215     }
216 
217     @Override
218     public PageInfo<T> findPageByHql(String hql, String countHql, int pageNo, int pageSize, Object... values) {
219         PageInfo<T> retValue = new PageInfo<T>();
220         Query query = this.getSession().createQuery(hql);
221         if (values != null) {
222             for (int i = 0; i < values.length; i++) {
223                 query.setParameter(i, values[i]);
224             }
225         }
226         int currentPage = pageNo > 1 ? pageNo : 1;
227         retValue.setPages(currentPage);
228         retValue.setPageSize(pageSize);
229         if (countHql == null) {
230             ScrollableResults results = query.scroll();
231             results.last();
232             retValue.setTotal(results.getRowNumber() + 1);
233         } else {
234             Long count = countByHql(countHql, values);
235             retValue.setTotal(count.intValue());
236         }
237         List<T> itemList = query.setFirstResult((currentPage - 1) * pageSize).setMaxResults(pageSize).list();
238         if (itemList == null) {
239             itemList = new ArrayList<T>();
240         }
241         retValue.setList(itemList);
242         return retValue;
243     }
244 
245 
246     @Override
247     public void merge(T entity) {
248         // TODO Auto-generated method stub
249         getSession().merge(entity);
250     }
251     
252     @Override
253     public boolean exists(PK id) {
254         return null != get(id);
255     }
256 
257     @Override
258     public int countAll() {
259         Criteria criteria = createCriteria();
260         return Integer.valueOf(criteria.setProjection(Projections.rowCount()).uniqueResult().toString());
261     }
262 
263     @Override
264     public int countAll(Criteria criteria) {
265         criteria.setProjection(null);
266         return Integer.valueOf(criteria.setProjection(Projections.rowCount()).uniqueResult().toString());
267     }
268     
269     @Override
270     public List<T> list(Criteria criteria) {
271         return criteria.list();
272     }
273 
274     @Override
275     public List<T> list(DetachedCriteria criteria) {
276         return (List<T>) list(criteria.getExecutableCriteria(getSession()));
277     }
278 
279     @Override
280     public List<T> list(String orderBy, boolean isAsc) {
281         Criteria criteria = createCriteria();
282         if (isAsc) {
283             criteria.addOrder(Order.asc(orderBy));
284         } else {
285             criteria.addOrder(Order.desc(orderBy));
286         }
287         return criteria.list();
288     }
289     
290     @Override
291     public List<T> list(String propertyName, Object value) {
292         Criterion criterion = Restrictions.like(propertyName, "%"+ value +"%");
293         return list(criterion);
294     }
295 
296 
297     @Override
298     public List<T> list(Criterion criterion) {
299         Criteria criteria = createCriteria();
300         criteria.add(criterion);
301         return criteria.list();
302     }
303 
304     @Override
305     public List<T> list(Criterion... criterions) {
306         return createCriteria(criterions).list();
307     }
308 
309     @Override
310     public T uniqueResult(String propertyName, Object value) {
311         Criterion criterion = Restrictions.eq(propertyName, value);
312         return (T) createCriteria(criterion).uniqueResult();
313     }
314 
315     @Override
316     public T uniqueResult(Criterion... criterions) {
317         Criteria criteria = createCriteria(criterions);
318         return uniqueResult(criteria);
319     }
320 
321     @Override
322     public T uniqueResult(Criteria criteria) {
323         return (T) criteria.uniqueResult();
324     }
325     
326     @Override
327     public Integer uniqueResultInt(Criteria criteria) {
328         return (Integer) criteria.uniqueResult();
329     }
330 
331 
332     @Override
333     public Criteria distinct(Criteria criteria) {
334         criteria.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY);
335         return criteria;
336     }
337 
338     @Override
339     public void flush() {
340         getSession().flush();
341     }
342 
343     @Override
344     public void clear() {
345         getSession().clear();
346     }
347 
348 
349     @Override
350     public Criteria createCriteria(Criterion... criterions) {
351         Criteria criteria = createCriteria();
352         for (Criterion c : criterions) {
353             criteria.add(c);
354         }
355         return criteria;
356     }
357 
358     @Override
359     public List<T> findPage(Criteria criteria, int pageNo, int pageSize) {
360         criteria.setFirstResult((pageNo - 1) * pageSize);
361         criteria.setMaxResults(pageSize);
362         return list(criteria);
363     }
364 
365     @Override
366     public PageInfo<T> findQuery(Criteria criteria, int pageNo, int pageSize) {
367         try {
368             Assert.isTrue(pageNo >= 1, "pageNO should start from 1");
369             while(criteria instanceof Subcriteria){
370                 criteria = ((Subcriteria)criteria).getParent();
371             }
372             //拆分order by子句  
373             while(criteria instanceof Subcriteria){
374                 criteria = ((Subcriteria)criteria).getParent();
375             }
376             Field field = CriteriaImpl.class.getDeclaredField("orderEntries");  
377             field.setAccessible(true);  
378             List<?> orderEntrys = (List<?>) field.get(criteria);  
379             field.set(criteria, new ArrayList());  
380             //统计总数
381             long totalCount = countAll(criteria);
382             criteria.setProjection(null);
383             //统计完了再把order by子句加上 这样保证了sql语句不会出错
384             field.set(criteria, orderEntrys);
385             List<T> list = findPage(criteria, pageNo, pageSize);
386             if (totalCount < 1) {
387                 return new PageInfo<T>();
388             }
389             PageInfo<T> page = new PageInfo<T>();
390             page.setPageNum(pageNo);
391             page.setTotal(totalCount);
392             page.setPages((int) (totalCount % pageSize == 0 ? totalCount / pageSize : totalCount / pageSize + 1));
393             page.setPageSize(pageSize);
394             page.setList(list);
395             return page;
396         } catch (Exception e) {
397             // TODO: handle exception
398             e.printStackTrace();
399             throw new QueryException("查询出错!");
400         }
401         
402     }
403 
404     @Override
405     public List<T> findQuery(String hql, int pageNo, int pageSize, Map<?, ?> map) {
406         // TODO Auto-generated method stub
407         if(null == hql) return null;
408         Query query = getSession().createQuery(hql);
409         for (Entry<?, ?> en : map.entrySet()) {
410             query.setParameter(en.getKey().toString(), en.getValue());
411         }
412         if(pageNo > 0) query.setFirstResult(pageNo);
413         if(pageSize > 0) query.setFirstResult(pageSize);
414         return query.list();
415     }
416 
417     @Override
418     public List<T> findAll() {
419         // TODO Auto-generated method stub
420         return createCriteria().list();
421     }
422 }
View Code

GenericService.java

  1 package com.agen.service;
  2 
  3 import java.io.Serializable;
  4 import java.util.Collection;
  5 import java.util.List;
  6 import java.util.Map;
  7 
  8 import org.hibernate.Criteria;
  9 import org.hibernate.criterion.Criterion;
 10 import org.hibernate.criterion.DetachedCriteria;
 11 
 12 import com.github.pagehelper.PageInfo;
 13 
 14 public interface GenericService<T, PK extends Serializable> {
 15     /**
 16      * 查询全部,可以排序
 17      * @param orderBy
 18      * @param isAsc
 19      * @return List<T>
 20      */
 21     public List<T> list(Criteria criteria);
 22 
 23     /**
 24      * 查询全部,可以排序
 25      * @param orderBy
 26      * @param isAsc
 27      * @return List<T>
 28      */
 29     public List<T> list(String orderBy, boolean isAsc);
 30     
 31     /**
 32      * 离线查询
 33      * @param criteria
 34      * @return List<T>
 35      */
 36     public List<T> list(DetachedCriteria criteria);
 37     
 38     /**
 39      * 根据Criteria查询条件,获取总数
 40      * @param criteria
 41      * @return int
 42      * @throws SecurityException 
 43      * @throws NoSuchFieldException 
 44      * @throws IllegalAccessException 
 45      * @throws IllegalArgumentException 
 46      */
 47     public int countAll(Criteria criteria);
 48     
 49     /**
 50      * 获取总数(默认为entityClass) 即查询总条数
 51      * @return int
 52      */
 53     public int countAll();
 54     
 55     /**
 56      * 根据I判断是否存在
 57      * @param id
 58      * @return boolean
 59      */
 60     public boolean exists(PK id);
 61     
 62     /**
 63      * 保存实体 
 64      * @param t 实体参数
 65      */
 66     public void save(T t);
 67 
 68     /**
 69      * 保存或者更新实体
 70      * @param t 实体
 71      */
 72     public void saveOrUpdate(T t);
 73 
 74     /**
 75      * 加载实体的通过load方法
 76      * @param id 实体的id
 77      * @return 查询出来的实体
 78      */
 79     public T load(PK id);
 80     
 81     /**
 82      * 合并实体 
 83      * @param entity
 84      */
 85     public void merge(T entity);
 86     
 87     /**
 88      * 查找全部
 89      */
 90     public List<T> findAll();
 91 
 92     /**
 93      * 通过get方法加载实体的
 94      * @param id 实体的id
 95      * @return 查询出来的实体
 96      */
 97     public T get(PK id);
 98 
 99     /**
100      * contains
101      * @param t 实体
102      * @return 是否包含
103      */
104     public boolean contains(T t);
105 
106     /**
107      * delete
108      * @param t
109      * 删除实体
110      */
111     public void delete(T t);
112 
113     /**
114      * 根据ID删除数据
115      * @param Id 实体id
116      * @return 是否删除成功
117      */
118     public boolean deleteById(PK Id);
119 
120     /**
121      * 删除所有
122      * @param entities 实体的Collection集合
123      */
124     public void deleteAll(Collection<T> entities);
125 
126     /**
127      * 执行Hql语句 要求 hql中参数顺序与可变参数 中参数顺序相一致
128      * @param hqlString hql
129      * @param values 不定参数数组
130      */
131     public void queryHql(String hqlString, Object... values);
132 
133     /**
134      * 执行Sql语句(不建议用,影响扩展)
135      * @param sqlString sql
136      * @param values 不定参数数组
137      */
138     public void querySql(String sqlString, Object... values);
139 
140     /**
141      * 根据HQL语句查找唯一实体
142      * 
143      * @param hqlString HQL语句
144      * @param values 不定参数的Object数组
145      * @return 查询实体
146      */
147     public T getByHQL(String hqlString, Object... values);
148     
149     /**
150      * 根据SQL语句查找唯一实体(不建议用,影响扩展)
151      * @param sqlString SQL语句
152      * @param values 不定参数的Object数组
153      * @return 查询实体
154      */
155 
156     /**
157      * 根据HQL语句,得到对应的list
158      * @param hqlString HQL语句
159      * @param values 不定参数的Object数组
160      * @return 查询多个实体的List集合
161      */
162     public List<T> getListByHQL(String hqlString, Object... values);
163 
164     /**
165      * 根据SQL语句,得到对应的list(不建议用,影响扩展)
166      * @param sqlString HQL语句
167      * @param values 不定参数的Object数组
168      * @return 查询多个实体的List集合
169      */
170     public List<T> getListBySQL(String sqlString, Object... values);
171 
172     /**
173      * refresh 刷新实体,强制与数据库两步 refresh方法应该是数据库的数据更新到本地的person实体中,而不是本地person更新数据到数据库中  也就是执行refresh方法是更新了java代码中变量的数据值
174      * @param t 实体
175      */
176     public void refresh(T t);
177 
178     /**
179      * update
180      * @param t
181      * 更新的是数据库中的数据
182      */
183     public void update(T t);
184 
185     /**
186      * 根据HQL得到记录数
187      * @param hql HQL语句
188      * @param values 不定参数的Object数组
189      * @return 记录总数
190      */
191     public Long countByHql(String hql, Object... values);
192 
193     /**
194      * HQL分页查询
195      * 
196      * @param hql HQL语句
197      * @param countHql 查询记录条数的HQL语句
198      * @param pageNo 下一页
199      * @param pageSize 一页总条数
200      * @param values  不定Object数组参数
201      * @return PageResults的封装类,里面包含了页码的信息以及查询的数据List集合
202      */
203     public  PageInfo<T> findPageByHql(String hql, String countHql, int pageNo, int pageSize, Object... values);
204     
205     /**
206      * 按属性查找对象列表,匹配方式为相等
207      * @param propertyName
208      * @param value
209      * @return List<T>
210      */
211     public List<T> list(String propertyName, Object value);
212     
213     /**
214      * 根据criterion查询条件获取数据列表
215      * @param criterion
216      * @return List<T>
217      */
218     public List<T> list(Criterion criterion);
219     
220     /**
221      * 按Criteria查询对象列表
222      * @param criterions
223      * @return List<T>
224      */
225     public List<T> list(Criterion... criterions);
226     
227     /**
228      * 按属性查找唯一对象,匹配方式为相等
229      * @param propertyName
230      * @param value
231      * @return T
232      */
233     public T uniqueResult(String propertyName, Object value);
234     
235     /**
236      * 按Criteria查询唯一对象
237      * @param criterions
238      * @return T
239      */
240     public T uniqueResult(Criterion... criterions);
241     
242     /**
243      * 按Criteria查询唯一对象
244      * @param criteria
245      * @return T
246      */
247     public T uniqueResult(Criteria criteria);
248     /**
249      * 按照criteria返回类型为Integer类型的某个字段的值
250      * @param criteria
251      * @return
252      */
253     public Integer uniqueResultInt(Criteria criteria);
254     
255     
256     
257     /**
258      * 为Criteria添加distinct transformer
259      * @param criteria
260      * @return Criteria
261      */
262     public Criteria distinct(Criteria criteria);
263     
264     /**
265      * 刷新session
266      */
267     public void flush();
268     
269     /**
270      * 清空session
271      */
272     public void clear();
273     
274     /**
275      * 创建Criteria实例
276      */
277     public Criteria createCriteria();
278     
279     /**
280      * 根据Criterion条件创建Criteria
281      * @param criterions
282      * @return Criteria
283      */
284     public Criteria createCriteria(Criterion... criterions);
285     
286     /**
287      * 分页查询Criteria
288      * @param criteria 
289      * @param pageNo 下页页码
290      * @param pageSize 页面数据量
291      * @return List<T>
292      */
293     public List<T> findPage(Criteria criteria, int pageNo, int pageSize);
294     
295     /**
296      * 分页查询Criteria
297      * @param criteria
298      * @param pageNo
299      * @param pageSize
300      * @return PageInfo<T>
301      * @throws SecurityException 
302      * @throws NoSuchFieldException 
303      * @throws IllegalAccessException 
304      * @throws IllegalArgumentException 
305      */
306     public PageInfo<T> findQuery(Criteria criteria, int pageNo, int pageSize);
307     
308     /**
309      * 
310      * @param hql
311      * @param pageNo
312      * @param pageSize
313      * @param map
314      * @return List<T>
315      */
316     public List<T> findQuery(String hql, int pageNo, int pageSize, Map<?, ?> map);
317 }
View Code

GenericServiceImpl.java

  1 package com.agen.service.impl;
  2 
  3 import java.io.Serializable;
  4 import java.util.Collection;
  5 import java.util.List;
  6 import java.util.Map;
  7 
  8 import org.hibernate.Criteria;
  9 import org.hibernate.criterion.Criterion;
 10 import org.hibernate.criterion.DetachedCriteria;
 11 import org.springframework.beans.factory.annotation.Autowired;
 12 import org.springframework.stereotype.Component;
 13 import org.springframework.stereotype.Service;
 14 import org.springframework.transaction.annotation.Propagation;
 15 import org.springframework.transaction.annotation.Transactional;
 16 
 17 import com.agen.dao.impl.GenericDaoImpl;
 18 import com.agen.service.GenericService;
 19 import com.github.pagehelper.PageInfo;
 20 
 21 @Transactional
 22 public class GenericServiceImpl<T, PK extends Serializable> implements GenericService<T, PK> {
 23 
 24     
 25     private GenericDaoImpl<T, PK> dao;
 26     /**
 27      * 设值注入Dao
 28      * @param dao
 29      */
 30     @Autowired
 31     public void setDao(GenericDaoImpl<T, PK> dao) {
 32         this.dao = dao;
 33     }
 34     
 35     @Override
 36     public List<T> list(Criteria criteria) {
 37         // TODO Auto-generated method stub
 38         return dao.list(criteria);
 39     }
 40 
 41     @Override
 42     public List<T> list(String orderBy, boolean isAsc) {
 43         // TODO Auto-generated method stub
 44         return dao.list(orderBy, isAsc);
 45     }
 46 
 47     @Override
 48     public List<T> list(DetachedCriteria criteria) {
 49         // TODO Auto-generated method stub
 50         return dao.list(criteria);
 51     }
 52 
 53     @Override
 54     public int countAll(Criteria criteria) {
 55         // TODO Auto-generated method stub
 56         return dao.countAll(criteria);
 57     }
 58 
 59     @Override
 60     public int countAll() {
 61         // TODO Auto-generated method stub
 62         return dao.countAll();
 63     }
 64 
 65     @Override
 66     public boolean exists(PK id) {
 67         // TODO Auto-generated method stub
 68         return dao.exists(id);
 69     }
 70 
 71     @Override
 72     @Transactional(propagation = Propagation.REQUIRED)
 73     public void save(T t) {
 74         // TODO Auto-generated method stub
 75         dao.save(t);
 76     }
 77 
 78     @Override
 79     @Transactional(propagation = Propagation.REQUIRED)
 80     public void saveOrUpdate(T t) {
 81         // TODO Auto-generated method stub
 82         dao.saveOrUpdate(t);
 83     }
 84 
 85     @Override
 86     @Transactional(propagation = Propagation.REQUIRED)
 87     public T load(PK id) {
 88         // TODO Auto-generated method stub
 89         return dao.load(id);
 90     }
 91 
 92     @Override
 93     @Transactional(propagation = Propagation.REQUIRED)
 94     public void merge(T entity) {
 95         // TODO Auto-generated method stub
 96         dao.merge(entity);
 97     }
 98 
 99     @Override
100     public List<T> findAll() {
101         // TODO Auto-generated method stub
102         return dao.findAll();
103     }
104 
105     @Override
106     @Transactional(propagation = Propagation.REQUIRED)
107     public T get(PK id) {
108         // TODO Auto-generated method stub
109         return dao.get(id);
110     }
111 
112     @Override
113     public boolean contains(T t) {
114         // TODO Auto-generated method stub
115         return dao.contains(t);
116     }
117 
118     @Override
119     public void delete(T t) {
120         // TODO Auto-generated method stub
121         dao.delete(t);
122     }
123 
124     @Override
125     @Transactional(propagation = Propagation.REQUIRED)
126     public boolean deleteById(PK Id) {
127         // TODO Auto-generated method stub
128         return dao.deleteById(Id);
129     }
130 
131     @Override
132     public void deleteAll(Collection<T> entities) {
133         // TODO Auto-generated method stub
134         dao.deleteAll(entities);
135     }
136 
137     @Override
138     public void queryHql(String hqlString, Object... values) {
139         // TODO Auto-generated method stub
140         dao.queryHql(hqlString, values);
141     }
142 
143     @Override
144     public void querySql(String sqlString, Object... values) {
145         // TODO Auto-generated method stub
146         dao.querySql(sqlString, values);
147     }
148 
149     @Override
150     public T getByHQL(String hqlString, Object... values) {
151         // TODO Auto-generated method stub
152         return dao.getByHQL(hqlString, values);
153     }
154 
155     @Override
156     public List<T> getListByHQL(String hqlString, Object... values) {
157         // TODO Auto-generated method stub
158         return dao.getListByHQL(hqlString, values);
159     }
160 
161     @Override
162     public List<T> getListBySQL(String sqlString, Object... values) {
163         // TODO Auto-generated method stub
164         return dao.getListBySQL(sqlString, values);
165     }
166 
167     @Override
168     public void refresh(T t) {
169         // TODO Auto-generated method stub
170         dao.refresh(t);
171     }
172 
173     @Override
174     @Transactional(propagation = Propagation.REQUIRED)
175     public void update(T t) {
176         // TODO Auto-generated method stub
177         dao.update(t);
178     }
179 
180     @Override
181     public Long countByHql(String hql, Object... values) {
182         // TODO Auto-generated method stub
183         return dao.countByHql(hql, values);
184     }
185 
186     @Override
187     public PageInfo<T> findPageByHql(String hql, String countHql, int pageNo,
188             int pageSize, Object... values) {
189         // TODO Auto-generated method stub
190         return dao.findPageByHql(hql, countHql, pageNo, pageSize, values);
191     }
192 
193     @Override
194     public List<T> list(String propertyName, Object value) {
195         // TODO Auto-generated method stub
196         return dao.list(propertyName, value);
197     }
198 
199     @Override
200     public List<T> list(Criterion criterion) {
201         // TODO Auto-generated method stub
202         return dao.list(criterion);
203     }
204 
205     @Override
206     public List<T> list(Criterion... criterions) {
207         // TODO Auto-generated method stub
208         return dao.list(criterions);
209     }
210 
211     @Override
212     public T uniqueResult(String propertyName, Object value) {
213         // TODO Auto-generated method stub
214         return dao.uniqueResult(propertyName, value);
215     }
216 
217     @Override
218     public T uniqueResult(Criterion... criterions) {
219         // TODO Auto-generated method stub
220         return dao.uniqueResult(criterions);
221     }
222 
223     @Override
224     @Transactional(propagation = Propagation.REQUIRED, readOnly = true)
225     public T uniqueResult(Criteria criteria) {
226         // TODO Auto-generated method stub
227         return dao.uniqueResult(criteria);
228     }
229     
230     @Override
231     @Transactional(propagation = Propagation.REQUIRED, readOnly = true)
232     public Integer uniqueResultInt(Criteria criteria){
233         return dao.uniqueResultInt(criteria);
234     }
235     
236     @Override
237     public Criteria distinct(Criteria criteria) {
238         // TODO Auto-generated method stub
239         return dao.distinct(criteria);
240     }
241 
242     @Override
243     public void flush() {
244         // TODO Auto-generated method stub
245         dao.flush();
246     }
247 
248     @Override
249     public void clear() {
250         // TODO Auto-generated method stub
251         dao.clear();
252     }
253 
254     @Override
255     public Criteria createCriteria() {
256         // TODO Auto-generated method stub
257         return dao.createCriteria();
258     }
259 
260     @Override
261     public Criteria createCriteria(Criterion... criterions) {
262         // TODO Auto-generated method stub
263         return dao.createCriteria(criterions);
264     }
265 
266     @Override
267     public List<T> findPage(Criteria criteria, int pageNo, int pageSize) {
268         // TODO Auto-generated method stub
269         return dao.findPage(criteria, pageNo, pageSize);
270     }
271 
272     @Override
273     public PageInfo<T> findQuery(Criteria criteria, int pageNo, int pageSize) {
274         // TODO Auto-generated method stub
275         return dao.findQuery(criteria, pageNo, pageSize);
276     }
277 
278     @Override
279     public List<T> findQuery(String hql, int pageNo, int pageSize, Map<?, ?> map) {
280         // TODO Auto-generated method stub
281         return dao.findQuery(hql, pageNo, pageSize, map);
282     }
283 
284 }
View Code

 

我将这几个文件保存在如下:

 

我们看到实体包下的各个实体:

 

接下来  自动生成每一层的各个实体对应的相对应的代码文件:【注意在执行之前,查看基础文件位置是否正确/注意基础文件中关于工作包的代码 是否正确】

  1 package com.sxd.utils;
  2 
  3 import java.io.File;
  4 import java.io.FileWriter;
  5 import java.io.IOException;
  6 
  7 import org.junit.Test;
  8 import org.springframework.util.FileCopyUtils;
  9 /**
 10  * 生成dao 、service等代码
 11  * @author Administrator
 12  *
 13  */
 14 public class CreateJava {
 15     
 16     //包名 前半部分[java文件中内容]
 17     private String packPath = "package com.sxd";
 18     //包名  中间部分 例如:com.sxd.entity
 19     private String middlePath = "sxd";
 20     //项目名 用于生成文件的路径
 21     private String productName = "shiro-first";
 22     //dao service等基础的文件存放的路径
 23     private String DaoServicePath = "F:/workspace2/DaoService";
 24     
 25     
 26     
 27     @Test
 28     public void mainTest() throws IOException{
 29         createFiles();//第一步 生成各层文件夹,并从固定位置copy 基础dao,service文件
 30         justCreateJava();//第二步 生成各个实体对应的Dao等层文件
 31     }
 32     
 33     
 34     public void justCreateJava() throws IOException{
 35         File file = new File("F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/entity");
 36         File []list = file.listFiles();
 37         for (File file2 : list) {
 38             String fileName = file2.getName().substring(0,file2.getName().lastIndexOf("."));
 39             createDao(fileName);
 40             createDaoImpl(fileName);
 41             createService(fileName);
 42             createServiceImpl(fileName);
 43         }
 44     }
 45     /**
 46      * 创建Dao层
 47      * @param fileName
 48      * @throws IOException 
 49      */
 50     public void createDao(String fileName) throws IOException{
 51         //拼接 DaoImpl内容
 52                 String content = packPath+".dao;\r\n"
 53                         + "\r\n"
 54                         + "import com."+middlePath+".entity."+fileName+";\r\n"
 55                         + "public interface "+fileName+"Dao extends GenericDao<"+fileName+", String> {\r\n"
 56                                 + "\r\n"
 57                                 + "}";
 58                 
 59                 //指定将Dao文件生成到对应的指定位置
 60                 FileWriter writer = new FileWriter(new File("F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/dao/"+fileName+"Dao.java"));
 61                 writer.write(content);
 62                 writer.close();
 63     }
 64     
 65     /**
 66      * 创建DaoImpl层
 67      */
 68     public void createDaoImpl(String fileName) throws IOException{
 69         //拼接 DaoImpl内容
 70         String content = packPath+".dao.Impl;\r\n"
 71                 + "\r\n"
 72                 + "import org.springframework.stereotype.Repository;\r\n"
 73                 + "import com."+middlePath+".dao."+fileName+"Dao;\r\n"
 74                 + "import com."+middlePath+".entity."+fileName+";\r\n"
 75                 + "@Repository \r\n"
 76                 + "public class "+fileName+"DaoImpl extends GenericDaoImpl<"+fileName+", String> implements "+fileName+"Dao {\r\n"
 77                         + "\r\n"
 78                 + "}";
 79         
 80         //指定将DaoImpl文件生成到对应的指定位置
 81         FileWriter writer = new FileWriter(new File("F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/dao/impl/"+fileName+"DaoImpl.java"));
 82         writer.write(content);
 83         writer.close();
 84     }
 85     
 86     /**
 87      * 创建 Service层
 88      * @param fileName
 89      * @throws IOException
 90      */
 91     public void createService(String fileName) throws IOException{
 92         //拼接Service内容
 93         String content = packPath+".service;\r\n"
 94                 + "import com."+middlePath+".entity."+fileName+";\r\n"
 95                 + "public interface "+fileName+"Service extends GenericService<"+fileName+", String> {\r\n"
 96                         + "\r\n"
 97                         + "}";
 98         
 99         FileWriter writer = new FileWriter(new File("F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/service/"+fileName+"Service.java"));
100         writer.write(content);
101         writer.close();
102     }
103     
104     /**
105      * 创建ServiceImpl
106      * @throws IOException 
107      */
108     public void createServiceImpl(String fileName) throws IOException{
109         //拼接Service内容
110                 String content = packPath+".service.Impl;\r\n"
111                         + "import org.springframework.beans.factory.annotation.Autowired;\r\n"
112                         + "import org.springframework.stereotype.Service;\r\n"
113                         + "import com."+middlePath+".dao."+fileName+"Dao;\r\n"
114                         + "import com."+middlePath+".entity."+fileName+";\r\n"
115                         + "import com."+middlePath+".service."+fileName+"Service;\r\n"
116                         + "@Service \r\n"
117                         + "public class "+fileName+"ServiceImpl extends GenericServiceImpl<"+fileName+", String> implements "+fileName+"Service {\r\n"
118                                 + "\r\n"
119                                 + "@Autowired\r\n"
120                                 + "private "+fileName+"Dao dao;\r\n"
121                                 + "}";
122                 FileWriter writer = new FileWriter(new File("F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/service/impl/"+fileName+"ServiceImpl.java"));
123                 writer.write(content);
124                 writer.close();
125     }
126     
127     
128     
129     /**
130      * 有了entity之后,创建各层文件夹,同时将 GenericDao等基础类和接口实现
131      * @throws IOException 
132      */
133     public void createFiles() throws IOException{
134         String daoPath = "F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/dao";
135         String servicePath = "F:/workspace2/"+productName+"/src/main/java/com/"+middlePath+"/service";
136         /**
137          * 上来先删除掉 如果存在的话
138          */
139         delFolder(daoPath);
140         delFolder(servicePath);
141         
142         /**
143          * 创建文件夹
144          */
145         File file = new File(daoPath);
146         file.mkdirs();
147         File file2 = new File(servicePath);
148         file2.mkdirs();
149         File file3 = new File(daoPath+"/Impl");
150         file3.mkdirs();
151         File file4 = new File(servicePath+"/Impl");
152         file4.mkdirs();
153         copyDaoAndServiceFile(daoPath,servicePath);
154         
155     }
156     
157     //删除文件夹
158     //param folderPath 文件夹完整绝对路径
159 
160          public  void delFolder(String folderPath) {
161          try {
162             delAllFile(folderPath); //删除完里面所有内容
163             String filePath = folderPath;
164             filePath = filePath.toString();
165             java.io.File myFilePath = new java.io.File(filePath);
166             myFilePath.delete(); //删除空文件夹
167          } catch (Exception e) {
168            e.printStackTrace(); 
169          }
170     }
171 
172     //删除指定文件夹下所有文件
173     //param path 文件夹完整绝对路径
174        public  boolean delAllFile(String path) {
175            boolean flag = false;
176            File file = new File(path);
177            if (!file.exists()) {
178              return flag;
179            }
180            if (!file.isDirectory()) {
181              return flag;
182            }
183            String[] tempList = file.list();
184            File temp = null;
185            for (int i = 0; i < tempList.length; i++) {
186               if (path.endsWith(File.separator)) {
187                  temp = new File(path + tempList[i]);
188               } else {
189                   temp = new File(path + File.separator + tempList[i]);
190               }
191               if (temp.isFile()) {
192                  temp.delete();
193               }
194               if (temp.isDirectory()) {
195                  delAllFile(path + "/" + tempList[i]);//先删除文件夹里面的文件
196                  delFolder(path + "/" + tempList[i]);//再删除空文件夹
197                  flag = true;
198               }
199            }
200            return flag;
201          }
202     
203        //将dao等基础文件 拷贝到 项目下固定包中
204        public void copyDaoAndServiceFile(String daoPath,String servicePath) throws IOException{
205            File file1 = new File(daoPath+"/GenericDao.java");
206            if(!file1.exists()){
207                file1.createNewFile();
208            }
209            File file2 = new File(daoPath+"/Impl/GenericDaoImpl.java");
210            if(!file2.exists()){
211                file2.createNewFile();
212            }
213            File file3 = new File(servicePath+"/GenericService.java");
214            if(!file3.exists()){
215                file3.createNewFile();
216            }
217            File file4 = new File(servicePath+"/Impl/GenericServiceImpl.java");
218            if(!file4.exists()){
219                file4.createNewFile();
220            }
221            FileCopyUtils.copy(new File(DaoServicePath+"/GenericDao.java"), file1);
222            FileCopyUtils.copy(new File(DaoServicePath+"/GenericDaoImpl.java"), file2);
223            FileCopyUtils.copy(new File(DaoServicePath+"/GenericService.java"), file3);
224            FileCopyUtils.copy(new File(DaoServicePath+"/GenericServiceImpl.java"), file4);
225            
226        }
227 }
View Code

 

 

生成完刷新

效果如下:

 

相关文章
|
2月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
92 9
|
14天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
74 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
16天前
|
Java Maven
java项目中jar启动执行日志报错:no main manifest attribute, in /www/wwwroot/snow-server/z-server.jar-jar打包的大小明显小于正常大小如何解决
在Java项目中,启动jar包时遇到“no main manifest attribute”错误,且打包大小明显偏小。常见原因包括:1) Maven配置中跳过主程序打包;2) 缺少Manifest文件或Main-Class属性。解决方案如下:
java项目中jar启动执行日志报错:no main manifest attribute, in /www/wwwroot/snow-server/z-server.jar-jar打包的大小明显小于正常大小如何解决
|
12天前
|
存储 Java BI
java怎么统计每个项目下的每个类别的数据
通过本文,我们详细介绍了如何在Java中统计每个项目下的每个类别的数据,包括数据模型设计、数据存储和统计方法。通过定义 `Category`和 `Project`类,并使用 `ProjectManager`类进行管理,可以轻松实现项目和类别的数据统计。希望本文能够帮助您理解和实现类似的统计需求。
55 17
|
1月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
92 34
|
1月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
138 26
|
2月前
|
XML Java 测试技术
从零开始学 Maven:简化 Java 项目的构建与管理
Maven 是一个由 Apache 软件基金会开发的项目管理和构建自动化工具。它主要用在 Java 项目中,但也可以用于其他类型的项目。
70 1
从零开始学 Maven:简化 Java 项目的构建与管理
|
2月前
|
SQL 安全 Java
Java 异常处理:筑牢程序稳定性的 “安全网”
本文深入探讨Java异常处理,涵盖异常的基础分类、处理机制及最佳实践。从`Error`与`Exception`的区分,到`try-catch-finally`和`throws`的运用,再到自定义异常的设计,全面解析如何有效管理程序中的异常情况,提升代码的健壮性和可维护性。通过实例代码,帮助开发者掌握异常处理技巧,确保程序稳定运行。
53 1
|
2月前
|
Java
Java项目中高精度数值计算:为何BigDecimal优于Double
在Java项目开发中,涉及金额计算、面积计算等高精度数值操作时,应选择 `BigDecimal` 而非 `Double`。`BigDecimal` 提供任意精度的小数运算、多种舍入模式和良好的可读性,确保计算结果的准确性和可靠性。例如,在金额计算中,`BigDecimal` 可以精确到小数点后两位,而 `Double` 可能因精度问题导致结果不准确。
|
2月前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
48 3