jiazx0107@163.com
2023-06-30 57351e2e19760732ac00225dfa82a2965e1823b5
igds-core/src/main/java/com/ld/igds/view/service/HDicAreaService.java
@@ -3,18 +3,18 @@
import com.bstek.bdf2.core.orm.hibernate.HibernateDao;
import com.bstek.dorado.data.provider.Page;
import com.ld.igds.models.DicArea;
import com.ld.igds.models.DicFoodOrigin;
import org.apache.commons.lang3.StringUtils;
import org.hibernate.Session;
import org.springframework.stereotype.Component;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@Component
public class HDicAreaService extends HibernateDao{
public class HDicAreaService extends HibernateDao {
    public List<DicArea> listDicArea(String type){
    public List<DicArea> listDicArea(String type) {
        String hql = " from " + DicArea.class.getName();
        Map<String, Object> args = new HashMap<String, Object>();
@@ -30,7 +30,6 @@
    public String saveDicArea(DicArea data) {
        Session session = this.getSessionFactory().openSession();
        try {
            session.saveOrUpdate(data);
        } finally {
            session.flush();
@@ -50,7 +49,7 @@
        return null;
    }
    public DicArea listDicAreaByName(String name){
    public DicArea listDicAreaByName(String name) {
        String hql = " from " + DicArea.class.getName() + " where 1=1";
        Map<String, Object> args = new HashMap<String, Object>();
@@ -61,14 +60,14 @@
        hql += " order by code";
        List<DicArea> list = this.query(hql, args);
        if(null ==list || list.isEmpty()){
        if (null == list || list.isEmpty()) {
            return null;
        }
        return list.get(0);
    }
    public DicArea listDicAreaByCode(String code){
        if(StringUtils.isEmpty(code)){
    public DicArea listDicAreaByCode(String code) {
        if (StringUtils.isEmpty(code)) {
            return null;
        }
        String hql = " from " + DicArea.class.getName() + " where code =:code";
@@ -78,52 +77,33 @@
        hql += " order by code";
        List<DicArea> list = this.query(hql, args);
        if(null ==list || list.isEmpty()){
        if (null == list || list.isEmpty()) {
            return null;
        }
        return list.get(0);
    }
    public void getDicArea(Page<DicFoodOrigin> page, Map<String,Object> param) throws Exception {
        String hql = " from " + DicArea.class.getName() + " where 1=1";
    public void pageList(Page<DicArea> page, String key) throws Exception {
        Map<String, Object> args = new HashMap<String, Object>();
        String hql = " from " + DicArea.class.getName();
        if (null != param) {
            String str = (String) param.get("code");
            if (StringUtils.isNotEmpty(str)) {
                hql += " and code like :code";
                args.put("code", "%" + str + "%");
            }
            str = (String) param.get("name");
            if (StringUtils.isNotEmpty(str)) {
                hql += " and name like :name";
                args.put("name", "%" + str + "%");
            }
        Map<String, Object> args = new HashMap<>();
        List<DicArea> list;
        String countHql;
        if (StringUtils.isNotEmpty(key)) {
            hql += " where (name like :key1 or simple like:key2)";
            args.put("key1", "%" + key + "%");
            args.put("key2", "%" + key.toUpperCase() + "%");
            str = (String) param.get("disabledTag");
            if (StringUtils.isNotEmpty(str)) {
                hql += " and disabledTag = :disabledTag";
                args.put("disabledTag", str);
            }
            countHql = "select count(1) " + hql;
            hql += " order by code";
            str = (String) param.get("key");
            if (StringUtils.isNoneEmpty(str)) {
                hql += " and (name like :name or code like:code or simple like:simple) ";
                args.put("name", "%" + str + "%");
                args.put("code", "%" + str + "%");
                args.put("simple", "%" + str.toUpperCase() + "%");
            }
        }
            this.pagingQuery(page, hql, countHql, args);
        String coutHql = "select count(*) " + hql;
        hql += " order by code";
        if (args.isEmpty()) {
            this.pagingQuery(page, hql, coutHql);
        } else {
            this.pagingQuery(page, hql, coutHql, args);
            countHql = "select count(1) " + hql;
            hql += " order by code";
            this.pagingQuery(page, hql, countHql);
        }
    }
}