Bonus-Cloud-JYY-Smart-Canteen/bonus-modules/bonus-smart-canteen/src/main/resources/mapper/ims/SupplierBindMaterialMapper.xml

121 lines
7.0 KiB
XML

<?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.bonus.canteen.core.ims.mapper.SupplierBindMaterialMapper">
<resultMap type="com.bonus.canteen.core.ims.domain.SupplierBindMaterial" id="SupplierBindMaterialResult">
<result property="id" column="id" />
<result property="canteenId" column="canteen_id" />
<result property="canteenName" column="canteen_name" />
<result property="areaName" column="area_name" />
<result property="supplierId" column="supplier_id" />
<result property="materialId" column="material_id" />
<result property="categoryId" column="category_id" />
<result property="alternativeSupplier" column="alternative_supplier" />
<result property="ifSupply" column="if_supply" />
<result property="materialCode" column="material_code" />
<result property="materialName" column="material_name" />
<result property="size" column="size" />
<result property="salePrice" column="sale_price" />
<result property="unitPrice" column="unit_price" />
<result property="materialTypeName" column="material_type_name" />
<result property="supplierName" column="supplier_name" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectSupplierBindMaterialVo">
select cm.material_id, cm.material_code, cm.material_name, cm.size, cm.sale_price, cm.unit_price,
cmt.material_type_name, isu.supplier_name, bc.canteen_name, ba.area_name,
isbm.id, isbm.canteen_id, isbm.supplier_id, isbm.material_id, isbm.category_id, isbm.alternative_supplier,
isbm.if_supply, isbm.create_by, isbm.create_time, isbm.update_by, isbm.update_time
from cook_material cm
left join ims_supplier_bind_material isbm on cm.material_id = isbm.material_id
left join cook_material_type cmt on cmt.material_type_id = cm.material_type_id
left join ims_supplier isu on isu.supplier_id = isbm.supplier_id
left join basic_canteen bc on bc.canteen_id = isbm.canteen_id
left join basic_area ba on ba.area_id = bc.area_id
</sql>
<select id="selectSupplierBindMaterialList" parameterType="com.bonus.canteen.core.ims.domain.SupplierBindMaterial" resultMap="SupplierBindMaterialResult">
<include refid="selectSupplierBindMaterialVo"/>
<where>
<if test="canteenId != null "> and isbm.canteen_id = #{canteenId}</if>
<if test="supplierId != null "> and isbm.supplier_id = #{supplierId}</if>
<if test="supplierName != null and supplierName != ''"> and isu.supplier_name like concat('%', #{supplierName}, '%')</if>
<if test="materialId != null "> and isbm.material_id = #{materialId}</if>
<if test="categoryId != null "> and isbm.category_id = #{categoryId}</if>
<if test="alternativeSupplier != null and alternativeSupplier != ''"> and isbm.alternative_supplier = #{alternativeSupplier}</if>
<if test="ifSupply != null "> and isbm.if_supply = #{ifSupply}</if>
<if test="materialTypeIds != null and materialTypeIds.size() > 0">
and cm.material_type_id in
<foreach collection="materialTypeIds" item="materialTypeId" separator="," open="(" close=")">
#{materialTypeId}
</foreach>
</if>
</where>
</select>
<select id="selectSupplierBindMaterialById" parameterType="Long" resultMap="SupplierBindMaterialResult">
<include refid="selectSupplierBindMaterialVo"/>
where isbm.id = #{id}
</select>
<insert id="insertSupplierBindMaterial" parameterType="com.bonus.canteen.core.ims.domain.SupplierBindMaterial" useGeneratedKeys="true" keyProperty="id">
insert into ims_supplier_bind_material
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="canteenId != null">canteen_id,</if>
<if test="supplierId != null">supplier_id,</if>
<if test="materialId != null">material_id,</if>
<if test="categoryId != null">category_id,</if>
<if test="alternativeSupplier != null">alternative_supplier,</if>
<if test="ifSupply != null">if_supply,</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>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="canteenId != null">#{canteenId},</if>
<if test="supplierId != null">#{supplierId},</if>
<if test="materialId != null">#{materialId},</if>
<if test="categoryId != null">#{categoryId},</if>
<if test="alternativeSupplier != null">#{alternativeSupplier},</if>
<if test="ifSupply != null">#{ifSupply},</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>
</trim>
</insert>
<update id="updateSupplierBindMaterial" parameterType="com.bonus.canteen.core.ims.domain.SupplierBindMaterial">
update ims_supplier_bind_material
<trim prefix="SET" suffixOverrides=",">
<if test="canteenId != null">canteen_id = #{canteenId},</if>
<if test="supplierId != null">supplier_id = #{supplierId},</if>
<if test="materialId != null">material_id = #{materialId},</if>
<if test="categoryId != null">category_id = #{categoryId},</if>
<if test="alternativeSupplier != null">alternative_supplier = #{alternativeSupplier},</if>
<if test="ifSupply != null">if_supply = #{ifSupply},</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>
</trim>
where id = #{id}
</update>
<delete id="deleteSupplierBindMaterialById" parameterType="Long">
delete from ims_supplier_bind_material where id = #{id}
</delete>
<delete id="deleteSupplierBindMaterialByIds" parameterType="String">
delete from ims_supplier_bind_material where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>