<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.op.quality.mapper.QcCheckTaskIncomeMapper"> <resultMap type="QcCheckTaskIncome" id="QcCheckTaskIncomeResult"> <result property="recordId" column="record_id"/> <result property="checkNo" column="check_no"/> <result property="incomeBatchNo" column="income_batch_no"/> <result property="orderNo" column="order_no"/> <result property="materialCode" column="material_code"/> <result property="materialName" column="material_name"/> <result property="quality" column="quality"/> <result property="noOkQuality" column="noOk_quality"/> <result property="unit" column="unit"/> <result property="supplierCode" column="supplier_code"/> <result property="supplierName" column="supplier_name"/> <result property="incomeTime" column="income_time"/> <result property="checkLoc" column="check_loc"/> <result property="checkStatus" column="check_status"/> <result property="checkManCode" column="check_man_code"/> <result property="checkManName" column="check_man_name"/> <result property="checkTime" column="check_time"/> <result property="checkResult" column="check_result"/> <result property="status" column="status"/> <result property="attr1" column="attr1"/> <result property="attr2" column="attr2"/> <result property="attr3" column="attr3"/> <result property="attr4" column="attr4"/> <result property="createBy" column="create_by"/> <result property="createTime" column="create_time"/> <result property="updateBy" column="update_by"/> <result property="updateTime" column="update_time"/> <result property="factoryCode" column="factory_code"/> <result property="delFlag" column="del_flag"/> <result property="checkType" column="check_type"/> <result property="sampleQuality" column="sample_quality"/> <result property="orderType" column="order_type"/> <result property="orderTypeDesc" column="order_type_desc"/> </resultMap> <sql id="selectQcCheckTaskIncomeVo"> select record_id, check_no, income_batch_no, order_no, material_code, material_name, quality, unit, supplier_code, supplier_name, income_time, check_loc, check_status, check_man_code, check_man_name, check_time, check_result, status, attr1, attr2, attr3, attr4, create_by, create_time, update_by, update_time, factory_code, del_flag , check_type,sample_quality, noOk_quality, order_type,order_type_desc from qc_check_task </sql> <select id="selectQcCheckTaskIncomeList" parameterType="QcCheckTaskIncome" resultMap="QcCheckTaskIncomeResult"> select qct.record_id, qct.check_no, qct.income_batch_no, qct.order_no, qct.material_code, qct.material_name, qct.quality, qct.unit, qct.supplier_code, qct.supplier_name, qct.income_time, qct.check_loc, qct.check_status, qct.check_man_code, qct.check_man_name,qct.check_time, qct.check_result, qct.status, qct.create_by,qct.create_time, qct.update_by, qct.update_time,qct.check_type,qct.noOk_quality, qct.sample_quality, qct.type_code, qct.order_type from qc_check_task qct <where> <if test="checkNo != null and checkNo != ''">and qct.check_no = #{checkNo}</if> <if test="incomeBatchNo != null and incomeBatchNo != ''">and qct.income_batch_no = #{incomeBatchNo}</if> <if test="orderNo != null and orderNo != ''">and qct.order_no = #{orderNo}</if> <if test="materialCode != null and materialCode != ''">and qct.material_code = #{materialCode}</if> <if test="materialName != null and materialName != ''">and qct.material_name like concat('%', #{materialName}, '%') </if> <if test="supplierCode != null and supplierCode != ''">and qct.supplier_code = #{supplierCode}</if> <if test="supplierName != null and supplierName != ''">and qct.supplier_name like concat('%', #{supplierName}, '%') </if> <if test="incomeTime != null ">and qct.income_time = #{incomeTime}</if> <if test="checkLoc != null and checkLoc != ''">and qct.check_loc = #{checkLoc}</if> <if test="checkStatus != null and checkStatus != ''">and qct.check_status = #{checkStatus}</if> <if test="checkManCode != null and checkManCode != ''">and qct.check_man_code = #{checkManCode}</if> <if test="checkManName != null and checkManName != ''">and qct.check_man_name like concat('%', #{checkManName}, '%') </if> <if test="checkResult != null and checkResult != ''">and qct.check_result = #{checkResult}</if> <if test="status != null and status != ''">and qct.status = #{status}</if> <if test="delFlag != null and delFlag != ''">and qct.del_flag = #{delFlag}</if> <if test="factoryCode != null and factoryCode != ''">and qct.factory_code = #{factoryCode}</if> <if test="incomeTimeStart != null ">and CONVERT(varchar(30),qct.income_time, 120) >= #{incomeTimeStart}</if> <if test="incomeTimeEnd != null ">and #{incomeTimeEnd} > CONVERT(varchar(30),qct.income_time, 120)</if> <if test="checkTimeStart != null ">and CONVERT(varchar(30),qct.check_time, 120) >= #{checkTimeStart}</if> <if test="checkTimeEnd != null ">and #{checkTimeEnd} > CONVERT(varchar(30),qct.check_time, 120)</if> <if test="checkType != null ">and qct.check_type = #{checkType}</if> <if test="typeCode != null ">and qct.type_code = #{typeCode}</if> <if test="orderType != null ">and qct.order_type = #{orderType}</if> </where> order by qct.create_time DESC </select> <select id="selectQcCheckTaskIncomeByRecordId" parameterType="String" resultMap="QcCheckTaskIncomeResult"> <include refid="selectQcCheckTaskIncomeVo"/> where record_id = #{recordId} </select> <select id="getQcListBom" resultType="com.op.quality.domain.QcBomComponent"> select product_code component,product_desc_zh componentName from base_product where del_flag = '0' <if test="component != null and component != ''">and product_code like concat('%', #{component}, '%')</if> <if test="componentName != null and componentName != ''">and product_desc_zh like concat('%', #{componentName}, '%') </if> </select> <select id="getQcListSupplier" resultType="com.op.quality.domain.QcSupplier"> select supplier_code supplierCode, zh_desc supplierName, address, contact_phone contactPhone from base_supplier where active_flag = '1' and del_flag ='0' <if test="supplierCode != null and supplierCode != ''">and supplier_code like concat('%', #{supplierCode}, '%') </if> <if test="supplierName != null and supplierName != ''">and zh_desc like concat('%', #{supplierName}, '%')</if> </select> <select id="getQcListUser" resultType="com.op.system.api.domain.SysUser"> select user_id userId, user_name userCode, nick_name userName, phonenumber from sys_user where del_flag = '0' and status = '0' <if test="userCode != null and userCode != ''">and user_name like concat('%', #{userCode}, '%')</if> <if test="userName != null and userName != ''">and nick_name like concat('%', #{userName}, '%')</if> </select> <select id="getTodayMaxNum" resultType="java.lang.Integer"> select count(0)+1 from qc_check_task where CONVERT(varchar(10),create_time, 120) = CONVERT(varchar(10),GETDATE(), 120) </select> <select id="getCkeckProjectList" resultType="com.op.quality.domain.QcCheckTaskDetail"> select td.record_id recordId, td.project_id projectId, td.project_no projectNo, td.rule_name ruleName, td.property_code propertyCode, td.check_mode checkMode, td.check_tool checkTool, td.unit_code unitCode, td.check_standard checkStandard, td.actual_value actualValue, td.status, td.remark, td.create_by createBy, td.create_time createTime, td.update_by updateBy, td.update_time updateTime, td.belong_to belongTo, td.defect_code defectCode, td.defect_quality defectQuality, qctp.upper_diff upperDiff, qctp.down_diff downDiff, qctp.sample from qc_check_task_detail td left join qc_check_type_project qctp on td.type_project_id = qctp.id where td.belong_to = #{belongTo} and td.del_flag='0' and qctp.del_flag = '0' and td.rule_name is not null order by qctp.sort </select> <select id="getQcUnitList" resultType="com.op.system.api.domain.SysDictData"> select dict_label dictLabel, dict_value dictValue from sys_dict_data where dict_type = 'unit' and status = '0' </select> <select id="getBatchList" resultType="com.op.quality.domain.QcCheckTaskIncome"> select powb.batch_id batchId, powb.batch_code batchCode from pro_order_workorder_batch powb left join pro_order_workorder pow on powb.workorder_id = pow.workorder_id where powb.del_flag = '0' and pow.del_flag = '0' and pow.workorder_code = #{workorderCode} order by powb.batch_code </select> <select id="getTypeCode" resultType="java.lang.String"> select type_code from qc_check_type where order_code = #{checkType} </select> <insert id="insertQcCheckTaskIncome" parameterType="QcCheckTaskIncome"> insert into qc_check_task <trim prefix="(" suffix=")" suffixOverrides=","> <if test="recordId != null">record_id,</if> <if test="checkNo != null">check_no,</if> <if test="incomeBatchNo != null">income_batch_no,</if> <if test="orderNo != null">order_no,</if> <if test="materialCode != null">material_code,</if> <if test="materialName != null">material_name,</if> <if test="quality != null">quality,</if> <if test="noOkQuality != null">noOk_quality,</if> <if test="unit != null">unit,</if> <if test="supplierCode != null">supplier_code,</if> <if test="supplierName != null">supplier_name,</if> <if test="incomeTime != null">income_time,</if> <if test="checkLoc != null">check_loc,</if> <if test="checkStatus != null">check_status,</if> <if test="checkManCode != null">check_man_code,</if> <if test="checkManName != null">check_man_name,</if> <if test="checkTime != null">check_time,</if> <if test="checkResult != null">check_result,</if> <if test="status != null">status,</if> <if test="attr1 != null">attr1,</if> <if test="attr2 != null">attr2,</if> <if test="attr3 != null">attr3,</if> <if test="attr4 != null">attr4,</if> <if test="createBy != null">create_by,</if> <if test="createTime != null">create_time,</if> <if test="updateBy != null">update_by,</if> <if test="updateTime != null">update_time,</if> <if test="factoryCode != null and factoryCode != ''">factory_code,</if> <if test="delFlag != null">del_flag,</if> <if test="checkType != null">check_type,</if> <if test="typeCode != null">type_code,</if> <if test="sampleQuality != null">sample_quality,</if> <if test="orderType != null">order_type,</if> <if test="orderTypeDesc != null">order_type_desc,</if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="recordId != null">#{recordId},</if> <if test="checkNo != null">#{checkNo},</if> <if test="incomeBatchNo != null">#{incomeBatchNo},</if> <if test="orderNo != null">#{orderNo},</if> <if test="materialCode != null">#{materialCode},</if> <if test="materialName != null">#{materialName},</if> <if test="quality != null">#{quality},</if> <if test="noOkQuality != null">#{noOkQuality},</if> <if test="unit != null">#{unit},</if> <if test="supplierCode != null">#{supplierCode},</if> <if test="supplierName != null">#{supplierName},</if> <if test="incomeTime != null">#{incomeTime},</if> <if test="checkLoc != null">#{checkLoc},</if> <if test="checkStatus != null">#{checkStatus},</if> <if test="checkManCode != null">#{checkManCode},</if> <if test="checkManName != null">#{checkManName},</if> <if test="checkTime != null">#{checkTime},</if> <if test="checkResult != null">#{checkResult},</if> <if test="status != null">#{status},</if> <if test="attr1 != null">#{attr1},</if> <if test="attr2 != null">#{attr2},</if> <if test="attr3 != null">#{attr3},</if> <if test="attr4 != null">#{attr4},</if> <if test="createBy != null">#{createBy},</if> <if test="createTime != null">#{createTime},</if> <if test="updateBy != null">#{updateBy},</if> <if test="updateTime != null">#{updateTime},</if> <if test="factoryCode != null and factoryCode != ''">#{factoryCode},</if> <if test="delFlag != null">#{delFlag},</if> <if test="checkType != null">#{checkType},</if> <if test="typeCode != null">#{typeCode},</if> <if test="sampleQuality != null">#{sampleQuality},</if> <if test="orderType != null">#{orderType},</if> <if test="orderTypeDesc != null">#{orderTypeDesc},</if> </trim> </insert> <update id="updateQcCheckTaskIncome" parameterType="QcCheckTaskIncome"> update qc_check_task <trim prefix="SET" suffixOverrides=","> <if test="checkNo != null">check_no = #{checkNo},</if> <if test="incomeBatchNo != null">income_batch_no = #{incomeBatchNo},</if> <if test="orderNo != null">order_no = #{orderNo},</if> <if test="materialCode != null">material_code = #{materialCode},</if> <if test="materialName != null">material_name = #{materialName},</if> <if test="quality != null">quality = #{quality},</if> <if test="noOkQuality != null">noOk_quality = #{noOkQuality},</if> <if test="unit != null">unit = #{unit},</if> <if test="supplierCode != null">supplier_code = #{supplierCode},</if> <if test="supplierName != null">supplier_name = #{supplierName},</if> <if test="incomeTime != null">income_time = #{incomeTime},</if> <if test="checkLoc != null">check_loc = #{checkLoc},</if> <if test="checkStatus != null">check_status = #{checkStatus},</if> <if test="checkManCode != null">check_man_code = #{checkManCode},</if> <if test="checkManName != null">check_man_name = #{checkManName},</if> <if test="checkTime != null">check_time = #{checkTime},</if> <if test="checkResult != null">check_result = #{checkResult},</if> <if test="status != null">status = #{status},</if> <if test="attr1 != null">attr1 = #{attr1},</if> <if test="attr2 != null">attr2 = #{attr2},</if> <if test="attr3 != null">attr3 = #{attr3},</if> <if test="attr4 != null">attr4 = #{attr4},</if> <if test="createBy != null">create_by = #{createBy},</if> <if test="createTime != null">create_time = #{createTime},</if> <if test="updateBy != null">update_by = #{updateBy},</if> <if test="updateTime != null">update_time = #{updateTime},</if> <if test="factoryCode != null and factoryCode != ''">factory_code = #{factoryCode},</if> <if test="delFlag != null">del_flag = #{delFlag},</if> <if test="checkType != null">check_type = #{checkType},</if> <if test="sampleQuality != null">sample_quality = #{sampleQuality},</if> </trim> where record_id = #{recordId} </update> <update id="updateQcCheckTask"> update qc_check_task set check_status = #{checkStatus}, check_man_code = #{checkManCode}, check_man_name =#{checkManName}, <if test="checkTime != null">check_time = #{checkTime},</if> <if test="sampleQuality != null">sample_quality = #{sampleQuality},</if> <if test="noOkQuality != null">noOk_quality = #{noOkQuality},</if> <if test="aNoOkquality != null">aNoOkquality = #{aNoOkquality},</if> <if test="bNoOkquality != null">bNoOkquality = #{bNoOkquality},</if> <if test="cNoOkquality != null">cNoOkquality = #{cNoOkquality},</if> <if test="incomeBatchNo != null">income_batch_no = #{incomeBatchNo},</if> check_result = #{checkResult}, update_by = #{updateBy}, update_time = #{updateTime} where record_id = #{recordId} </update> <update id="updateQcCheckTaskDetails"> <foreach collection="list" item="item" separator=";"> update qc_check_task_detail set actual_value = #{item.actualValue}, status = #{item.status}, update_by = #{item.updateBy}, update_time = #{item.updateTime}, remark = #{item.remark}, defect_code = #{item.defectCode}, defect_quality = #{item.defectQuality} where record_id = #{item.recordId} </foreach> </update> <delete id="deleteQcCheckTaskIncomeByRecordId" parameterType="String"> delete from qc_check_task where record_id = #{recordId} </delete> <delete id="deleteQcCheckTaskIncomeByRecordIds" parameterType="String"> delete from qc_check_task where record_id in <foreach item="recordId" collection="array" open="(" separator="," close=")"> #{recordId} </foreach> </delete> <delete id="deleteQcCheckTaskDefects"> delete from qc_check_task_defect where belong_to = #{belongId} </delete> <select id="selectQcCheckTaskCheckNoByRecordIds" parameterType="String" resultMap="QcCheckTaskIncomeResult"> select check_no from qc_check_task where record_id in <foreach item="recordId" collection="array" open="(" separator="," close=")"> #{recordId} </foreach> </select> <select id="getUserByCheckType" resultType="com.op.system.api.domain.quality.QcUserMaterialDTO"> select user_code userCode, user_name userName from qc_user_material where material_code = #{checkType} and del_flag = '0' </select> <select id="getCheckUser" resultType="com.op.system.api.domain.quality.QcUserMaterialDTO"> select user_code userCode, user_name userName from qc_user_material where material_code = #{checkType} and del_flag = '0' <if test = "orderType!=null"> and attr1 = #{orderType} </if> </select> <select id="getCkeckDefectList" resultType="com.op.quality.domain.QcCheckTaskDefect"> select qctd.defect_code defectCode, qctd.defect_subclass defectSubclass, sum(qctd.noOk_quality) noOkQuality from qc_check_task_defect qctd where qctd.del_flag = '0' and qctd.belong_to = #{belongTo} group by qctd.defect_code,qctd.defect_subclass order by qctd.defect_code </select> <select id="getDefectType" resultType="com.op.quality.domain.QcCheckTaskDefect"> select defect_code defectCode, defect_subclass defectSubclass from qc_defect_type qdt left join qc_check_type qct on qdt.defect_type = qct.type_code where qct.order_code = #{checkType} and qdt.del_flag = '0' order by qdt.defect_code </select> <select id="getTaskInfo" resultType="com.op.quality.domain.QcCheckTaskIncome"> select qct.material_code materialCode, qct.material_name materialName, qct.supplier_code supplierCode, qct.supplier_name supplierName, qct.income_batch_no incomeBatchNo, qct.quality, qct.factory_code factoryCode, case when pow.workorder_code_sap is not null then pow.workorder_code_sap else qct.order_no end orderNo, qct.create_time createTime, qct.check_no checkNo, qct.check_time checkTime, qct.check_result checkResult, qct.income_time incomeTime, qct.check_loc checkLoc from qc_check_task qct left join pro_order_workorder pow on pow.workorder_code = qct.order_no where qct.record_id = #{recordId} </select> <select id="getCkeckTaskXJList" resultType="com.op.quality.domain.QcCheckTaskIncome"> select record_id recordId, check_no checkNo, income_batch_no incomeBatchNo, check_status checkStatus, check_man_code checkManCode, check_man_name checkManName, check_time checkTime, check_result checkResult, create_time createTime, check_loc checkLoc, sample_quality sampleQuality from qc_check_task where del_flag = '0' and check_type = 'checkTypeSCXJ' and order_no = #{orderNo} </select> <insert id="addCheckUsers"> insert into qc_check_task_user( record_id,belong_to,check_no, check_man_code,check_man_name, create_by,create_time,factory_code ) values <foreach item="item" index="index" collection="list" separator=","> ( #{item.id},#{item.belongTo},#{item.checkNo}, #{item.userCode},#{item.userName}, #{item.createBy},#{item.createTime},#{item.factoryCode} ) </foreach> </insert> <insert id="addQcCheckTaskDefects"> insert into qc_check_task_defect( record_id,belong_to,belong_to_detail, defect_code,defect_subclass, noOk_quality, create_by,create_time,factory_code ) values <foreach item="item" index="index" collection="list" separator=","> ( #{item.recordId},#{item.belongTo},#{item.belongToDetail}, #{item.defectCode},#{item.defectSubclass}, #{item.noOkQuality}, #{item.createBy},#{item.createTime},#{item.factoryCode} ) </foreach> </insert> <!--查询原始表--> <select id="getIncomeBatchList" resultMap="QcCheckTaskIncomeResult"> select * from qc_income_original where del_flag = '0' and check_type = 'checkTypeLL' and order_type = 'bc' and check_status = '0' </select> <select id="getCheckLocList" resultType="com.op.quality.domain.QcDefectType"> select equipment_code defectCode, equipment_name defectSubclass from base_equipment where equipment_type_code='equ_type_bzx' and status = '1' </select> <select id="getTodayIncomeLists" resultType="java.lang.String"> select attr1 from qc_check_task where check_type = 'checkTypeLL' and CONVERT(varchar(10),GETDATE(), 120) = CONVERT(varchar(10),create_time, 120) </select> <!--批量更新原始表--> <update id="updateIncomeBatchList"> <foreach collection="list" item="item" separator=";"> update qc_income_original set check_status = '1', check_time = #{time} where record_id = #{item} </foreach> </update> </mapper>