ProductAttributeInfoDaoImpl.java
package com.mycim.server.spec.dao.impl;
import com.mycim.framework.jdbc.JdbcTemplate;
import com.mycim.server.spec.dao.ProductAttributeInfoDao;
import com.mycim.server.spec.dao.mapper.ProductAttributeInfoMapper;
import com.mycim.valueobject.prp.ProductAttributeInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import java.util.ArrayList;
import java.util.List;
@Repository
public class ProductAttributeInfoDaoImpl implements ProductAttributeInfoDao {
@Autowired
JdbcTemplate jdbcTemplate;
@Override
public void insertProductAttributeInfos(List<ProductAttributeInfo> productAttributeInfos) {
StringBuilder sql = new StringBuilder("INSERT INTO ");
sql.append(" PROD_ATTRIBUTE_INFO ");
sql.append(" (PRODUCT_RRN, PRODUCT_ID, PRODUCT_VERSION, PROCESS_RRN, PROCESS_ID, PROCESS_VERSION, ");
sql.append(" ACTIVE_FLAG, ACTIVE_TIME, ACTIVE_USER, CURRENT_STATUS, ");
sql.append(" LAST_UPDATED_USER, LAST_UPDATED_TIME, CREATE_USER_ID, CREATE_TIME) ");
sql.append(" VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) ");
List<Object[]> batchArgs = new ArrayList<>();
for (ProductAttributeInfo attributeInfo : productAttributeInfos) {
batchArgs
.add(new Object[]{attributeInfo.getProductRrn(), attributeInfo.getProductId(),
attributeInfo.getProductVersion(), attributeInfo.getProcessRrn(),
attributeInfo.getProcessId(), attributeInfo.getProcessVersion(),
attributeInfo.getActiveFlag(), attributeInfo.getActiveTime(),
attributeInfo.getActiveUser(), attributeInfo.getCurrentStatus(),
attributeInfo.getLastUpdatedUser(), attributeInfo.getLastUpdatedTime(),
attributeInfo.getCreateUserId(), attributeInfo.getCreateTime()});
}
jdbcTemplate.batchUpdate(sql.toString(), batchArgs);
}
@Override
public void deleteProductAttributeInfos(List<ProductAttributeInfo> productAttributeInfos) {
StringBuilder sql = new StringBuilder("delete from ");
sql.append(" PROD_ATTRIBUTE_INFO ");
sql.append(" where PRODUCT_RRN = ? and PRODUCT_VERSION = ? and PROCESS_RRN = ? and PROCESS_VERSION = ? ");
List<Object[]> batchArgs = new ArrayList<>();
for (ProductAttributeInfo attributeInfo : productAttributeInfos) {
batchArgs
.add(new Object[]{attributeInfo.getProductRrn(), attributeInfo.getProductVersion(),
attributeInfo.getProcessRrn(), attributeInfo.getProcessVersion()});
}
jdbcTemplate.batchUpdate(sql.toString(), batchArgs);
}
@Override
public void updateStatusOfProductAttributeInfos(List<ProductAttributeInfo> productAttributeInfos) {
StringBuilder sql = new StringBuilder("update ");
sql.append(" PROD_ATTRIBUTE_INFO ");
sql.append(" set ACTIVE_FLAG = ?, ACTIVE_TIME = ?, ACTIVE_USER = ?, ");
sql.append(" CURRENT_STATUS = ?, LAST_UPDATED_USER = ?, LAST_UPDATED_TIME = ? ");
sql.append(" where PRODUCT_RRN = ? and PRODUCT_VERSION = ? and PROCESS_RRN = ? and PROCESS_VERSION = ? ");
List<Object[]> batchArgs = new ArrayList<>();
for (ProductAttributeInfo attributeInfo : productAttributeInfos) {
batchArgs
.add(new Object[]{attributeInfo.getActiveFlag(), attributeInfo.getActiveTime(),
attributeInfo.getActiveUser(), attributeInfo.getCurrentStatus(),
attributeInfo.getLastUpdatedUser(), attributeInfo.getLastUpdatedTime(),
attributeInfo.getProductRrn(), attributeInfo.getProductVersion(),
attributeInfo.getProcessRrn(), attributeInfo.getProcessVersion()});
}
jdbcTemplate.batchUpdate(sql.toString(), batchArgs);
}
@Override
public ProductAttributeInfo getProductAttributeInfoByPrimaryKey(Long productRrn, Integer productVersion,
Long processRrn, Integer processVersion) {
StringBuilder sql = new StringBuilder("select ");
sql.append(" PRODUCT_RRN, PRODUCT_ID, PRODUCT_VERSION, PROCESS_RRN, PROCESS_ID, PROCESS_VERSION, ");
sql.append(" ACTIVE_FLAG, ACTIVE_TIME, ACTIVE_USER, CURRENT_STATUS, ");
sql.append(" LAST_UPDATED_USER, LAST_UPDATED_TIME, CREATE_USER_ID, CREATE_TIME ");
sql.append(" from PROD_ATTRIBUTE_INFO ");
sql.append(" where PRODUCT_RRN = ? and PRODUCT_VERSION = ? and PROCESS_RRN = ? and PROCESS_VERSION = ? ");
return jdbcTemplate
.queryForObjectWithNull(sql.toString(), new ProductAttributeInfoMapper(), productRrn, productVersion,
processRrn, processVersion);
}
@Override
public List<ProductAttributeInfo> getProductAttributeInfoWithPrimaryKey(
ProductAttributeInfo attributeInfoQueryTemp) {
StringBuilder sql = new StringBuilder("select ");
sql.append(" PRODUCT_RRN, PRODUCT_ID, PRODUCT_VERSION, PROCESS_RRN, PROCESS_ID, PROCESS_VERSION, ");
sql.append(" ACTIVE_FLAG, ACTIVE_TIME, ACTIVE_USER, CURRENT_STATUS, ");
sql.append(" LAST_UPDATED_USER, LAST_UPDATED_TIME, CREATE_USER_ID, CREATE_TIME ");
sql.append(" from PROD_ATTRIBUTE_INFO WHERE 1 = 1 ");
List<Object> args = new ArrayList<>();
if (attributeInfoQueryTemp.getProductRrn() != null && attributeInfoQueryTemp.getProductRrn() > 0) {
sql.append(" and PRODUCT_RRN = ?");
args.add(attributeInfoQueryTemp.getProductRrn());
}
if (attributeInfoQueryTemp.getProductVersion() != null && attributeInfoQueryTemp.getProductVersion() > 0) {
sql.append(" and PRODUCT_VERSION = ?");
args.add(attributeInfoQueryTemp.getProductVersion());
}
if (attributeInfoQueryTemp.getProcessRrn() != null && attributeInfoQueryTemp.getProcessRrn() > 0) {
sql.append(" and PROCESS_RRN = ?");
args.add(attributeInfoQueryTemp.getProcessRrn());
}
if (attributeInfoQueryTemp.getProcessVersion() != null && attributeInfoQueryTemp.getProcessVersion() > 0) {
sql.append(" and PROCESS_VERSION = ?");
args.add(attributeInfoQueryTemp.getProcessVersion());
}
return jdbcTemplate.query(sql.toString(), new ProductAttributeInfoMapper(), args.toArray());
}
}