package com.utopiaindustries.dao.ctp; import com.utopiaindustries.model.ctp.JobCard; import com.utopiaindustries.util.KeyHolderFunctions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.namedparam.MapSqlParameterSource; import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate; import org.springframework.jdbc.support.GeneratedKeyHolder; import org.springframework.jdbc.support.KeyHolder; import org.springframework.stereotype.Repository; import java.util.ArrayList; import java.util.List; @Repository public class JobCardDAO { @Autowired private NamedParameterJdbcTemplate namedParameterJdbcTemplate; private final String TABLE_NAME = "cut_to_pack.job_card"; private final String SELECT_QUERY = String.format( "SELECT * FROM %s WHERE id = :id", TABLE_NAME ); private final String SELECT_ALL_QUERY = String.format( "SELECT * FROM %s ORDER BY id DESC", TABLE_NAME ); private final String SELECT_ALL_QUERY_WITH_LIMIT = String.format( "SELECT * FROM %s ORDER BY id DESC limit :limit", TABLE_NAME ); private final String DELETE_QUERY = String.format( "DELETE FROM %s WHERE id = :id", TABLE_NAME ); private final String INSERT_QUERY = String.format( "INSERT INTO %s (id, code, job_order_id, created_at, created_by, status, inventory_status, customer, lot_number, purchase_order_id, location_site_id, description, poQuantity, articleName) VALUES (:id, :code, :job_order_id, :created_at, :created_by, :status, :inventory_status, :customer, :lot_number, :purchase_order_id, :location_site_id, :description, :poQuantity, :articleName) ON DUPLICATE KEY UPDATE code = VALUES(code), job_order_id = VALUES(job_order_id), created_at = VALUES(created_at), created_by = VALUES(created_by), status = VALUES(status), inventory_status = VALUES(inventory_status), customer = VALUES(customer), lot_number = VALUES(lot_number), purchase_order_id = VALUES(purchase_order_id), location_site_id = VALUES(location_site_id), description = VALUES(description), poQuantity = VALUES(poQuantity), articleName = VALUES(articleName) ", TABLE_NAME ); private final String SELECT_BY_LIKE_CODE_AND_INV_STATUS_AND_STATUS = String.format( "SELECT * FROM %s WHERE code like :code AND status = :status AND inventory_status = :inventory_status", TABLE_NAME ); private final String SELECT_BY_LIKE_CODE = String.format( "SELECT * FROM %s WHERE code like :code", TABLE_NAME ); private final String SELECT_BY_LIMIT = String.format( "SELECT * FROM %s WHERE created_by = :created_by ORDER BY id ASC limit :limit", TABLE_NAME ); // prepare query params private MapSqlParameterSource prepareInsertQueryParams( JobCard jobCard ) { MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue( "id", jobCard.getId() ) .addValue("code", jobCard.getCode() ) .addValue( "job_order_id", jobCard.getJobOrderId() ) .addValue( "created_at", jobCard.getCreatedAt() ) .addValue( "created_by", jobCard.getCreatedBy() ) .addValue("status", jobCard.getStatus() ) .addValue("inventory_status", jobCard.getInventoryStatus() ) .addValue("customer", jobCard.getCustomer() ) .addValue("poQuantity", jobCard.getPoQuantity() ) .addValue("articleName", jobCard.getArticleName() ) .addValue("lot_number", jobCard.getLotNumber() ) .addValue("purchase_order_id", jobCard.getPurchaseOrderId() ) .addValue("location_site_id", jobCard.getLocationSiteId() ) .addValue("description", jobCard.getDescription() ); return params; } // find public JobCard find( long id ) { MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue( "id", id ); return namedParameterJdbcTemplate.query( SELECT_QUERY, params, new JobCardRowMapper() ) .stream() .findFirst() .orElse( new JobCard() ); } // find all public List findAll() { return namedParameterJdbcTemplate.query( SELECT_ALL_QUERY, new JobCardRowMapper() ); } // save public long save( JobCard jobCard ) { KeyHolder keyHolder = new GeneratedKeyHolder(); MapSqlParameterSource params = prepareInsertQueryParams( jobCard ); namedParameterJdbcTemplate.update( INSERT_QUERY, params, keyHolder ); return KeyHolderFunctions.getKey( jobCard.getId(), keyHolder ); } // save all public int[] saveAll( List jobCards ) { List batchArgs = new ArrayList<>(); for ( JobCard jobCard: jobCards ) { MapSqlParameterSource params = prepareInsertQueryParams( jobCard ); batchArgs.add( params ); } return namedParameterJdbcTemplate.batchUpdate( INSERT_QUERY, batchArgs.toArray(new MapSqlParameterSource[jobCards.size()]) ); } // delete public boolean delete( long id ) { MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue( "id", id ); return namedParameterJdbcTemplate.update( DELETE_QUERY, params ) > 0; } public List findLikeCode( String code ) { MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue("code", "%" + code + "%"); return namedParameterJdbcTemplate.query(SELECT_BY_LIKE_CODE, params, new JobCardRowMapper()); } public List findLikeCode( String code , String inventoryStatus, String status ){ MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue( "code", "%" + code + "%" ); params.addValue("inventory_status", inventoryStatus ); params.addValue("status", status ); return namedParameterJdbcTemplate.query(SELECT_BY_LIKE_CODE_AND_INV_STATUS_AND_STATUS, params, new JobCardRowMapper() ); } public List findByUserAndLimit( String createdBy, Long limit ){ MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue("limit", limit.intValue() ); params.addValue("created_by", createdBy ); return namedParameterJdbcTemplate.query( SELECT_BY_LIMIT, params, new JobCardRowMapper() ); } public List findByQuery( String query ){ return namedParameterJdbcTemplate.query( query, new JobCardRowMapper() ); } public List findByAllWithLimit(Long limit){ MapSqlParameterSource params = new MapSqlParameterSource(); params.addValue("limit", limit.intValue()); return namedParameterJdbcTemplate.query( SELECT_ALL_QUERY_WITH_LIMIT, params, new JobCardRowMapper() ); } }