PodDAOImpl.java

package com.mycim.server.carrier.dao.impl;

import com.mycim.framework.jdbc.JdbcTemplate;
import com.mycim.framework.jdbc.mapper.RowMapper;
import com.mycim.framework.utils.MiscUtils;
import com.mycim.framework.utils.lang.StringUtils;
import com.mycim.framework.utils.lang.collections.MapUtils;
import com.mycim.framework.utils.lang.time.DateUtils;
import com.mycim.server.carrier.dao.CarrierDAO;
import com.mycim.server.carrier.dao.PodDAO;
import com.mycim.server.carrier.dao.mapper.PodMapper;
import com.mycim.valueobject.ObjectList;
import com.mycim.valueobject.consts.DataBaseNames;
import com.mycim.valueobject.consts.TransactionNames;
import com.mycim.valueobject.ems.POD;
import com.mycim.valueobject.ems.PcdAssembly;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Repository
public class PodDAOImpl implements PodDAO {

    private final static Long DEFAULT_SLOT_COUNT = new Long(25);

    @Autowired
    JdbcTemplate jdbcTemplate;

    @Autowired
    CarrierDAO carrierDAO;

    @Override
    public POD getPod(long podRrn) {
        POD pod = null;
        // get the value object by object rrn
        String sql = "select n.instance_rrn, noe.flag_type, n.named_space, n.object_type, n.object, n" +
                ".instance_id, n.instance_desc, n.instance_status, " + "es.current_status, p.mcs_move_status, p" +
                ".mcs_last_move_time, p" + ".mcs_last_operator_rrn, p" + ".eqpt_rrn, p.job_rrn, p.run_rrn, " + "p" +
                ".pod_map_rrn, p.load_position, " + "p.pollution_level, p.pod_code, getinstanceid(e" +
                ".allowable_events_rrn) as " + "allowable_events_id, " + "n.object_subtype as pod_type, getinstanceid" +
                "(e.maintenance_engineer_rrn) as " + "engineer_group_id " + "from pod p, entity e,named_object n left" +
                " join named_object_ext noe on n" + ".instance_rrn = noe.instance_rrn left join entity_status es on n" +
                ".instance_rrn = es" + ".entity_rrn " + "where n.instance_rrn = p.pod_rrn " + "and n.instance_rrn = e" +
                ".entity_rrn and n.instance_rrn = ?";

        Object[] params = new Object[]{podRrn};

        pod = jdbcTemplate.queryForObject(sql, params, new PodMapper());
        return pod;
    }

    @Override
    public Map<String, Object> qryPodInfoDetailById(String podId, String namedSpace) {
        Map<String, Object> dataMap = new HashMap();
        dataMap.put("podId", podId);
        dataMap.put("namedSpace", namedSpace);
        String sql = this.getPodListSql(dataMap);
        dataMap = jdbcTemplate.queryForObject(sql, new RowMapper<Map>() {

            @Override
            public Map mapRow(ResultSet rs, int rowNum) throws SQLException {
                Map<String, Object> dataMap = new HashMap();
                dataMap.put("podId", rs.getString("instance_id"));
                dataMap.put("podRrn", rs.getLong("instance_rrn"));
                dataMap.put("podDesc", rs.getString("instance_desc"));
                dataMap.put("podInstanceStatus", rs.getString("instance_status"));
                dataMap.put("podStatus", rs.getString("current_status"));
                dataMap.put("podPollution", rs.getString("pollution_level"));
                dataMap.put("podColor", rs.getString("pod_code"));
                dataMap.put("podAllowable", rs.getString("allowable_events_id"));
                dataMap.put("podType", rs.getString("pod_type"));
                dataMap.put("podEngineer", rs.getString("engineer_group_id"));
                String createTime = rs.getString("TRANS_START_TIMESTAMP");
                if (StringUtils.isNotBlank(createTime)) {
                    createTime = (createTime.split("\\."))[0];
                }
                dataMap.put("podCreateTime", createTime);
                dataMap.put("podCreateUser", rs.getString("create_user"));
                dataMap.put("podCategory", rs.getString("category_data"));
                dataMap.put("podComment", rs.getString("pod_comment"));
                return dataMap;
            }
        });
        return dataMap;
    }

    @Override
    public void insertPodH(Long podRrn, String comments, Long transRrn) {
        Map basicInfo = carrierDAO.getBasicHistInfo(podRrn);

        StringBuilder sql = new StringBuilder("INSERT INTO POD_H ");

        sql.append(" (POD_RRN, SLOT_COUNT, AVAILABLE_SLOT_COUNT, POD_CODE, ");
        sql.append(" MCS_MOVE_STATUS, MCS_LAST_MOVE_TIME, MCS_LAST_OPERATOR_RRN, ");
        sql.append(" EQPT_RRN, JOB_RRN, RUN_RRN, POD_MAP_RRN, LOAD_POSITION,POLLUTION_LEVEL,status,");
        sql.append(
                " FLAG_TYPE,OBJECT_SUBTYPE,DESCription,ALLOWABLE_EVENTS_RRN,MAINTENANCE_ENGINEER_RRN," + "COMMENTS,");
        sql.append(" LOT_ID,TARGET_POD,TRANS_RRN)");
        sql.append(" (SELECT POD_RRN, SLOT_COUNT, AVAILABLE_SLOT_COUNT, POD_CODE, ");
        sql.append(" MCS_MOVE_STATUS, MCS_LAST_MOVE_TIME, MCS_LAST_OPERATOR_RRN, ");
        sql.append(
                " EQPT_RRN, JOB_RRN, RUN_RRN, POD_MAP_RRN, LOAD_POSITION,POLLUTION_LEVEL,STATUS,?,?,?,?,?," + "?,?,?," +
                        "? ");
        sql.append(" FROM POD WHERE POD_RRN = ?) ");

        jdbcTemplate.update(sql.toString(),
                            new Object[]{MapUtils.getString(basicInfo, "category"), MapUtils.getString(basicInfo,
                                                                                                       "objectType"),
                                    MapUtils.getString(
                                    basicInfo, "instanceDesc"), MapUtils.getLong(basicInfo,
                                                                                 "allowableRrn"), MapUtils.getLong(
                                    basicInfo, "engineerRrn"), comments, MapUtils.getString(basicInfo,
                                                                                            "lotId"), "", transRrn,
                                    podRrn});
    }

    @Override
    public void updatePodByDeassembly(Long transRrn, POD pod) {
        String sql = "update pod set mcs_move_status=?, mcs_last_move_time=?, mcs_last_operator_rrn=?, " + "eqpt_rrn" +
                "=?, job_rrn=?, run_rrn=?, load_position=?, pollution_level=?, " + "status=? where pod_rrn = ?";
        jdbcTemplate.update(sql,
                            new Object[]{pod.getMcsMoveStatus(), pod.getMcsLastMoveTime(),
                                    pod.getMcsLastOperatorRrn(), pod.getEqptRrn(), pod.getJobRrn(), pod.getRunRrn(),
                                    pod.getLoadPosition(), pod.getPollutionLevel(), pod.getPodStatus(),
                                    pod.getInstanceRrn()});

        insertPodH(pod.getInstanceRrn(), StringUtils.EMPTY, transRrn);
    }

    @Override
    public void updatePodStatus(PcdAssembly pcdAssembly, Long transRrn, String status, String lotId) {
        String sql = " UPDATE POD SET STATUS = ? WHERE POD_RRN=?";
        jdbcTemplate.update(sql, new Object[]{status, pcdAssembly.getPodRrn()});

        insertPodH(pcdAssembly.getPodRrn(), transRrn, lotId);
    }

    @Override
    public void deletePod(POD pod, Long transRrn) {
        long instanceRrn = pod.getInstanceRrn();
        insertPodH(instanceRrn, StringUtils.EMPTY, transRrn);
        String sql = "DELETE FROM " + DataBaseNames.POD + " WHERE POD_RRN = " + instanceRrn;
        jdbcTemplate.update(sql);
    }

    @Override
    public void insertPod(POD pod, Long transRrn) {
        long instanceRrn = pod.getInstanceRrn();
        Object[] obj = {(pod.getSlotCount() == null) ? DEFAULT_SLOT_COUNT : pod
                .getSlotCount(), pod.getAvailableSlotCount(), pod.getCarrierCode(), pod.getMcsMoveStatus(),
                pod.getMcsLastMoveTime(), pod.getMcsLastOperatorRrn(), pod.getEqptRrn(), pod.getJobRrn(),
                pod.getRunRrn(), pod.getCarrierMapRrn(), pod.getLoadPosition(), pod.getPollutionLevel(),
                pod.getPodStatus()};

        String sql = "INSERT INTO " + DataBaseNames.POD + " (POD_RRN,SLOT_COUNT,AVAILABLE_SLOT_COUNT," + "POD_CODE," +
                "MCS_MOVE_STATUS,MCS_LAST_MOVE_TIME," + "MCS_LAST_OPERATOR_RRN,EQPT_RRN,JOB_RRN,RUN_RRN," +
                "POD_MAP_RRN,LOAD_POSITION,POLLUTION_LEVEL,STATUS)" + " VALUES (" + instanceRrn + "," +
                MiscUtils.parseSQL(obj) + ")";
        jdbcTemplate.update(sql);

        insertPodH(instanceRrn, "", transRrn);
    }

    @Override
    public void updatePod(POD pod, Long transRrn) {
        String sql = "UPDATE NAMED_OBJECT SET INSTANCE_DESC = ?,OBJECT_SUBTYPE = ?,LAST_UPDATE_TIMESTAMP = " +
                "sysdate WHERE INSTANCE_RRN = ?";
        jdbcTemplate.update(sql, new Object[]{pod.getInstanceDesc(), pod.getObjectSubtype(), pod.getInstanceRrn()});
        String sql2 = "UPDATE POD SET POD_CODE=?,POLLUTION_LEVEL=? WHERE POD_RRN = ?";
        jdbcTemplate.update(sql2, new Object[]{pod.getCarrierCode(), pod.getPollutionLevel(), pod.getInstanceRrn()});

        String sql3 = "UPDATE ENTITY SET ALLOWABLE_EVENTS_RRN=?,MAINTENANCE_ENGINEER_RRN=? WHERE ENTITY_RRN" + " =?";
        jdbcTemplate.update(sql3,
                            new Object[]{pod.getAllowableEventsRrn(), pod.getMaintenanceEngineerRrn(),
                                    pod.getInstanceRrn()});

        insertPodH(pod.getInstanceRrn(), StringUtils.EMPTY, transRrn);
    }

    @Override
    public int getPodTotalCount(Map<String, Object> argMap) {
        int count = 0;
        String countSql = "select count(*) from (" + getPodListSql(argMap) + ") countt";
        count = this.jdbcTemplate.queryForObject(countSql, int.class);
        return count;
    }

    @Override
    public List<Map> getPodListByPage(Map<String, Object> argMap, int startRow, int currentTotalRow) {
        String rownumSql = "select * from (select rownum as rowno, rowt.* from (" + getPodListSql(argMap) +
                ")rowt )rowtt where rowno <= ? ";
        String pageSql = "select * from (" + rownumSql + ") paget where rowno > ? ";
        return jdbcTemplate.query(pageSql, new Object[]{currentTotalRow, startRow}, new RowMapper<Map>() {

            @Override
            public Map mapRow(ResultSet rs, int rowNum) throws SQLException {
                Map<String, Object> dataMap = new HashMap<String, Object>();
                dataMap.put("podId", rs.getString("instance_id"));
                dataMap.put("podRrn", rs.getLong("instance_rrn"));
                dataMap.put("podDesc", rs.getString("instance_desc"));
                dataMap.put("podInstanceStatus", rs.getString("instance_status"));
                dataMap.put("podStatus", rs.getString("current_status"));
                dataMap.put("podPollution", rs.getString("pollution_level"));
                dataMap.put("podColor", rs.getString("pod_code"));
                dataMap.put("podAllowable", rs.getString("allowable_events_id"));
                dataMap.put("podType", rs.getString("pod_type"));
                dataMap.put("podEngineer", rs.getString("engineer_group_id"));
                String createTime = rs.getString("TRANS_START_TIMESTAMP");
                if (StringUtils.isNotBlank(createTime)) {
                    createTime = (createTime.split("\\."))[0];
                }
                dataMap.put("podCreateTime", createTime);
                dataMap.put("podCreateUser", rs.getString("create_user"));
                dataMap.put("podCategory", rs.getString("category_data"));
                dataMap.put("podCleanOverDate", rs.getString("clean_over_date"));
                dataMap.put("podRemainCleanDay", rs.getString("remain_clean_day"));

                dataMap.put("podSlotCount", rs.getString("slot_count"));
                dataMap.put("podLoadPosition", rs.getString("load_position"));
                dataMap.put("podCategoryCode", rs.getString("category_code"));
                return dataMap;
            }
        });
    }

    private String getPodListSql(Map<String, Object> argMap) {

        String paramSql1 = "";
        if (StringUtils.isNotBlank(MapUtils.getString(argMap, "podId"))) {
            paramSql1 += " and n.instance_id like '" + MapUtils.getString(argMap, "podId") + "' ";
        }
        if (StringUtils.isNotBlank(MapUtils.getString(argMap, "status"))) {
            paramSql1 += " and es.current_status = '" + MapUtils.getString(argMap, "status") + "' ";
        }
        if (StringUtils.isNotBlank(MapUtils.getString(argMap, "type"))) {
            paramSql1 += " and n.object_subtype = '" + MapUtils.getString(argMap, "type") + "' ";
        }
        if (StringUtils.isNotBlank(MapUtils.getString(argMap, "category"))) {
            paramSql1 += " and noe.flag_type = '" + MapUtils.getString(argMap, "category") + "' ";
        }

        String namedSpace = MapUtils.getString(argMap, "namedSpace").toUpperCase();

        String sql = "select distinct pod_info.clean_over_date, pod_info.remain_clean_day, " + "create_trans_info" +
                ".TRANS_PERFORMED_BY || ' ' || user_info.instance_desc as " + "create_user, to_char(new_comment" +
                ".entity_comment) as pod_comment," + "create_trans_info.TRANS_START_TIMESTAMP, ref_category" +
                ".category_data, ref_category" + ".category_code, " + "pod_info.instance_rrn, pod_info.instance_id, " +
                "pod_info.instance_desc, pod_info" + ".instance_status, pod_info.current_status," + "pod_info" +
                ".pollution_level, pod_info.pod_code, pod_info.allowable_events_id, pod_info" + ".pod_type, pod_info" +
                ".engineer_group_id, " + "pod_info.load_position, pod_info.slot_count, " +
                " least(COALESCE(cst_clean_over_date, door_clean_over_date, pod_info.clean_over_date), "+
                " COALESCE(pod_info.clean_over_date, cst_clean_over_date, door_clean_over_date), "+
                "  COALESCE(door_clean_over_date,  pod_info.clean_over_date,cst_clean_over_date))  as clean_leastDate "+
                "from (select n" +
                ".instance_rrn, noe.flag_type, n.instance_id, n.instance_desc, n" + ".instance_status, es" +
                ".current_status, p.pollution_level, p.pod_code, " + "getinstanceid(e.allowable_events_rrn) as " +
                "allowable_events_id, n.object_subtype as " + "pod_type, pc.clean_over_date, " + " to_char(TRUNC" +
                "(clean_over_date - sysdate, 2),'fm9999999990.00') as remain_clean_day, " + "getinstanceid(e" +
                ".maintenance_engineer_rrn) as engineer_group_id, p.load_position, p" + ".slot_count, " +
                "  (select temp_pc1.CLEAN_OVER_DATE from PCD_CLEAN temp_pc1 where temp_pc1.INSTANCE_RRN = asbly.CARRIER_RRN) as cst_clean_over_date, "+
                " (select temp_pc2.CLEAN_OVER_DATE from PCD_CLEAN temp_pc2  where temp_pc2.INSTANCE_RRN = asbly.DOOR_RRN)  as door_clean_over_date "+
                "from  pod " +
                "p, entity e,entity_status es, " + "named_object n left join NAMED_OBJECT_EXT NOE on n.instance_rrn =" +
                " noe.instance_rrn " + "left join pcd_clean pc on n.instance_rrn = pc.instance_rrn left join PCD_ASSEMBLY asbly on asbly.POD_RRN = n.INSTANCE_RRN  " +
                "where n" +
                ".instance_rrn = p.pod_rrn and n.instance_rrn = e.entity_rrn and n" + ".instance_rrn = es.entity_rrn " +
                "and n.named_space = '" + namedSpace + "' and n.object = '" + ObjectList.ENTITY_KEY + "' and n" +
                ".object_type = '" + ObjectList.POD_KEY + "' " + paramSql1 + ") pod_info left join " + "(select TL" +
                ".TRANS_START_TIMESTAMP, TL.TRANS_PERFORMED_BY, ph.pod_rrn  from " + "transaction_log tl, pod_h ph, " +
                "(select MAX(TL.TRANS_START_TIMESTAMP) AS TRANS_START_TIMESTAMP, ph.pod_rrn from " +
                "pod_h ph, transaction_log tl " + "where ph.trans_rrn = tl.trans_rrn and tl.trans_id = '" +
                TransactionNames.CREATE_KEY + "' GROUP BY ph.pod_rrn) max_create_time_info " +
                "where tl.trans_start_timestamp = max_create_time_info.TRANS_START_TIMESTAMP and tl" + ".trans_id = '" +
                TransactionNames.CREATE_KEY + "' " +
                "and ph.trans_rrn = tl.trans_rrn and ph.pod_rrn = max_create_time_info.pod_rrn) " +
                "create_trans_info on pod_info.instance_rrn = create_trans_info.pod_rrn left join " +
                "(select instance_id, instance_desc from named_object where object = '" + ObjectList.USER_KEY +
                "') user_info on create_trans_info.trans_performed_by = user_info.instance_id left " + "join " +
                "(select refd.key_1_value as category_code, refd.data_1_value as category_data from " +
                "reference_file_detail refd, named_object n " +
                "where n.instance_id = '$PCD_CATEGORY' and n.named_space = 'MYCIM2' and n" +
                ".instance_rrn = refd.reference_file_rrn) ref_category on pod_info.flag_type = " +
                "ref_category.category_code left join " + "(select e1.entity_rrn, e1.create_time, e1.entity_comment " +
                "from entity_comment_h e1, (select e.entity_rrn, max(e.create_time) as " +
                "max_create_time from entity_comment_h e group by e.entity_rrn) e2 " +
                "where e1.entity_rrn = e2.entity_rrn and e1.create_time = e2.max_create_time) " + "new_comment on  " +
                " new_comment.entity_rrn = pod_info.instance_rrn "
                // + "order by create_trans_info.trans_start_timestamp desc";
                + "order by clean_leastDate, pod_info.instance_id asc ";
        return sql;
    }

    private void insertPodH(Long podRrn, Long transRrn, String lotId) {
        Map basicInfo = carrierDAO.getBasicHistInfo(podRrn);

        StringBuilder sql = new StringBuilder("INSERT INTO POD_H ");

        sql.append(" (POD_RRN, SLOT_COUNT, AVAILABLE_SLOT_COUNT, POD_CODE, ");
        sql.append(" MCS_MOVE_STATUS, MCS_LAST_MOVE_TIME, MCS_LAST_OPERATOR_RRN, ");
        sql.append(" EQPT_RRN, JOB_RRN, RUN_RRN, POD_MAP_RRN, LOAD_POSITION,POLLUTION_LEVEL,status,");
        sql.append(
                " FLAG_TYPE,OBJECT_SUBTYPE,DESCription,ALLOWABLE_EVENTS_RRN,MAINTENANCE_ENGINEER_RRN," + "COMMENTS,");
        sql.append(" LOT_ID,TARGET_POD,TRANS_RRN)");
        sql.append(" (SELECT POD_RRN, SLOT_COUNT, AVAILABLE_SLOT_COUNT, POD_CODE, ");
        sql.append(" MCS_MOVE_STATUS, MCS_LAST_MOVE_TIME, MCS_LAST_OPERATOR_RRN, ");
        sql.append(
                " EQPT_RRN, JOB_RRN, RUN_RRN, POD_MAP_RRN, LOAD_POSITION,POLLUTION_LEVEL,STATUS,?,?,?,?,?," + "?,?,?," +
                        "? ");
        sql.append(" FROM POD WHERE POD_RRN = ?) ");

        jdbcTemplate.update(sql.toString(),
                            new Object[]{MapUtils.getString(basicInfo, "category"), MapUtils.getString(basicInfo,
                                                                                                       "objectType"),
                                    MapUtils.getString(
                                    basicInfo, "instanceDesc"), MapUtils.getLong(basicInfo,
                                                                                 "allowableRrn"), MapUtils.getLong(
                                    basicInfo, "allowableRrn"), "", (StringUtils.isNotBlank(lotId) ? lotId : MapUtils
                                    .getString(basicInfo, "lotId")), "", transRrn, podRrn});
    }

    @Override
    public String generatePodId(String prefix,int width) {
        String  sql = " select INSTANCE_ID from  ";
        sql+= " (select nob.INSTANCE_ID from pod  left join NAMED_OBJECT nob on  nob.INSTANCE_RRN = POD_RRN ";
        sql+=" where nob.INSTANCE_ID like ? and trim(translate(nvl(replace(nob.INSTANCE_ID,?,''),'x'),'0123456789',' ')) is null ";
        sql+=" order by to_number(replace(nob.INSTANCE_ID, ?, '')) desc  )";
        sql+=" where ROWNUM = 1 ";
        String likeParam = prefix+StringUtils.repeat("_",width);
        String podId =jdbcTemplate.queryForObjectWithNull(sql,new Object[]{likeParam,prefix,prefix},String.class);
        if(StringUtils.isEmpty(podId)){//从1开始
            return prefix+StringUtils.repeat("0",width-1)+"1";
        }
        //累加操作 //数据转换 在sql已经检查了
        long value = Long.parseLong(podId.replace(prefix,""));
        value++;
        if(value> Long.parseLong(StringUtils.repeat("9",width))){
            return "-1";
        }
        return prefix+StringUtils.leftPad(String.valueOf(value),width,"0");
    }

    @Override
    public void updatePodType(POD pod, String comments, Long transRrn) {
        Date date = DateUtils.parse(DateUtils.getNowTime());
        String sql = "UPDATE NAMED_OBJECT SET OBJECT_SUBTYPE = ?,LAST_UPDATE_TIMESTAMP = ? WHERE INSTANCE_RRN = ?";
        jdbcTemplate.update(sql, new Object[]{pod.getObjectSubtype() ,date ,pod.getInstanceRrn()});
        insertPodH(pod.getInstanceRrn(), comments, transRrn);
    }

}