my de sheng ho

/**
* 根據ID刪除記錄
*
* @param id
*/
public void removeByIdForAnnotation(Serializable id) {
T o = get(id);
if (o.getClass().isAnnotationPresent(Undeletable.class)) {
Undeletable anno = (Undeletable) o.getClass().getAnnotation(
Undeletable.class);
try {
Method method = o.getClass().getDeclaredMethod(
"set" + StringUtils.capitalize(anno.status()),
String.class);
try {
method.invoke(o, new Object[] { anno.value() });
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} catch (SecurityException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
}
save(o);
} else {
remove(o);
}
}

/**
* hql 刪除
*
* @param hql
*/
public void deleteByHql(String hql) {
Query query = getHibernateTemplate().getSessionFactory()
.getCurrentSession().createQuery(hql);
query.executeUpdate();
}

/**
* 條件查詢(帶緩存)
*
* @param hsql
* @param values
* @return 數據
*/
@SuppressWarnings("unchecked")
public List<T> findForCache(String hsql, Object... values) {
Query query = getHibernateTemplate().getSessionFactory()
.getCurrentSession().createQuery(hsql).setCacheable(true);
if (values == null || values.length == 0) {
return query.list();
} else {
for (int i = 0; i < values.length; i++) {
query.setParameter(i, values[i]);
}
return query.list();
}
}

/**
* 條件查詢QBC(帶緩存)
*
* @param criterions
* @return List<T>
*/
@SuppressWarnings("unchecked")
public List<T> findByQbcForCache(Criterion... criterions) {
Criteria criteria = getHibernateTemplate().getSessionFactory()
.getCurrentSession().createCriteria(getEntityClass());
criteria.setCacheable(true);
if (criterions != null && criterions.length != 0) {
for (Criterion c : criterions) {
criteria.add(c);
}
}
return criteria.list();
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章