<?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.ruoyi.system.mapper.TErpGoodsMapper">
|
|
<!-- 通用查询映射结果 -->
|
<resultMap id="BaseResultMap" type="com.ruoyi.system.model.TErpGoods">
|
<id column="id" property="id"/>
|
<result column="supplier_clinic_id" property="supplierClinicId"/>
|
<result column="goods_source" property="goodsSource"/>
|
<result column="clinic_id" property="clinicId"/>
|
<result column="goods_name" property="goodsName"/>
|
<result column="goods_id_code" property="goodsIdCode"/>
|
<result column="quasi_number" property="quasiNumber"/>
|
<result column="manufacturer" property="manufacturer"/>
|
<result column="formulation_spec" property="formulationSpec"/>
|
<result column="packing_spec" property="packingSpec"/>
|
<result column="type_id" property="typeId"/>
|
<result column="goods_yards" property="goodsYards"/>
|
<result column="maintenance_interval" property="maintenanceInterval"/>
|
<result column="low_purchase_quantity" property="lowPurchaseQuantity"/>
|
<result column="low_unit_id" property="lowUnitId"/>
|
<result column="is_prescription_drug" property="isPrescriptionDrug"/>
|
<result column="goods_spec" property="goodsSpec"/>
|
<result column="warning_inventory" property="warningInventory"/>
|
<result column="sales_amount" property="salesAmount"/>
|
<result column="packing_unit_id" property="packingUnitId"/>
|
<result column="instructions_use" property="instructionsUse"/>
|
<result column="side_effect" property="sideEffect"/>
|
<result column="clinic_purchase_price" property="clinicPurchasePrice"/>
|
<result column="platform_commission_price" property="platformCommissionPrice"/>
|
<result column="create_time" property="createTime"/>
|
<result column="update_time" property="updateTime"/>
|
<result column="create_by" property="createBy"/>
|
<result column="update_by" property="updateBy"/>
|
<result column="disabled" property="disabled"/>
|
</resultMap>
|
|
<!-- 通用查询结果列 -->
|
<sql id="Base_Column_List">
|
id
|
, supplier_clinic_id, goods_source, goods_name, goods_id_code, quasi_number, manufacturer, formulation_spec, packing_spec, type_id, goods_yards, maintenance_interval,maintenance_interval_unit, low_purchase_quantity, low_unit_id, is_prescription_drug, goods_spec, warning_inventory, sales_amount, packing_unit_id, instructions_use, side_effect, clinic_purchase_price, platform_commission_price, create_time, update_time, create_by,`state`, update_by, disabled,
|
simplified_code,
|
dosage_form,
|
usage_classification,
|
product_brand,
|
place_of_origin,
|
ingredient,
|
trait,
|
indication,
|
taboo,
|
precautions,
|
interaction,
|
storage,supplier_name
|
|
</sql>
|
|
|
<select id="pageList" resultType="com.ruoyi.system.vo.TErpGoodsVO">
|
select
|
t1.id
|
, t1.supplier_clinic_id, t1.goods_source, t1.goods_name, t1.goods_id_code, t1.quasi_number, t1.manufacturer, t1.formulation_spec, t1.packing_spec, t1.type_id, t1.goods_yards, t1.maintenance_interval, t1.maintenance_interval_unit, t1.low_purchase_quantity, t1.low_unit_id, t1.is_prescription_drug, t1.goods_spec, t1.warning_inventory, t1.sales_amount, t1.packing_unit_id, t1.instructions_use, t1.side_effect, t1.clinic_purchase_price, t1.platform_commission_price, t1.create_time, t1.update_time, t1.create_by, t1.`state`, t1.update_by, t1.disabled,
|
t1.simplified_code,
|
t1.dosage_form,
|
t1.usage_classification,
|
t1.product_brand,
|
t1.place_of_origin,
|
t1.ingredient,
|
t1.trait,
|
t1.indication,
|
t1.taboo,
|
t1.precautions,
|
t1.interaction,
|
t1.storage,
|
case t1.goods_source
|
when 1 then t2.supplier_name
|
when 2 then t1.supplier_name
|
end as supplierName
|
from t_erp_goods t1 left join t_crm_supplier t2 on t1.supplier_clinic_id = t2.id where t1.disabled = 0
|
<if test="query.supplierName != null and query.supplierName != ''">
|
and (t1.supplier_name like concat('%',#{query.supplierName},'%') or t2.supplier_name like concat('%',#{query.supplierName},'%'))
|
</if>
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and t1.goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
|
<if test="query.goodsIdCode != null and query.goodsIdCode != ''">
|
and t1.goods_id_code like concat('%',#{query.goodsIdCode},'%')
|
</if>
|
<if test="query.typeId != null and query.typeId != ''">
|
and t1.type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t1.quasi_number like concat('%',#{query.quasiNumber},'%')
|
</if>
|
<if test="query.state != null ">
|
and t1.state = #{query.state}
|
</if>
|
<if test="user.roleType != null and user.roleType == 4 ">
|
and t1.goods_source =1 and t1.supplier_clinic_id = #{query.supplierClinicId}
|
</if>
|
<if test="user.roleType != null and user.roleType == 5 ">
|
and ( ( t1.goods_source =2 and t1.supplier_clinic_id = #{query.supplierClinicId} ) or (FIND_IN_SET(#{query.supplierClinicId}, t1.clinic_ids) and t1.state =1))
|
</if>
|
order by t1.create_time desc
|
</select>
|
|
|
<select id="listExport" resultType="com.ruoyi.system.vo.TErpGoodsVO">
|
select
|
<include refid="Base_Column_List"/>
|
from t_erp_goods where disabled = 0
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
<if test="query.goodsIdCode != null and query.goodsIdCode != ''">
|
and goods_id_code like concat('%',#{query.goodsIdCode},'%')
|
</if>
|
<if test="query.typeId != null and query.typeId != ''">
|
and type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and quasi_number like concat('%',#{query.quasiNumber},'%')
|
</if>
|
<if test="query.state != null ">
|
and state = #{query.state}
|
</if>
|
<if test="user.roleType != null and user.roleType == 4 ">
|
and goods_source =1 and supplier_clinic_id =#{query.supplierClinicId}
|
</if>
|
<if test="user.roleType != null and user.roleType == 5 ">
|
and goods_source =2 and supplier_clinic_id =#{query.supplierClinicId}
|
</if>
|
order by create_time desc
|
</select>
|
|
|
<select id="pageInventoryGoodsPageList" resultType="com.ruoyi.system.vo.TErpGoodsInventoryVO">
|
select * from (
|
SELECT t1.id,t2.warehouse_no,
|
t3.goods_name,
|
t4.supplier_name,
|
t3.type_id,
|
t3.packing_unit_id,
|
t3.quasi_number,
|
t3.goods_id_code,
|
t1.batch_number,
|
coalesce(sum(t5.outbound_count),0) as outbound_count,
|
t1.warehousing_number,
|
t2.create_time,
|
t1.warehousing_number - coalesce(sum(t5.outbound_count),0) as num,
|
t2.unit_amount as sales_amount,
|
t1.expiry_date
|
from t_erp_supplier_warehousing_batch t1
|
LEFT JOIN t_erp_supplier_warehousing t2 on t1.warehousing_id = t2.id
|
LEFT JOIN t_erp_goods t3 on t2.goods_id = t3.id
|
LEFT JOIN t_crm_supplier t4 on t3.supplier_clinic_id = t4.id
|
LEFT JOIN t_erp_supplier_outbound_goods t5 on t5.warehousing_batch_id =t1.id
|
where t2.disabled = 0 and t2.warehouse_id = #{query.warehouseId}
|
<if test="query.type != null and query.type ==1">
|
and #{time} > t1.expiry_date
|
</if>
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and t3.goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
<if test="user.roleType !=null and user.roleType ==4">
|
and t3.supplier_clinic_id =#{supplierClinicId} and t3.goods_source=1
|
</if>
|
<if test="user.roleType !=null and user.roleType ==5">
|
and t3.supplier_clinic_id =#{supplierClinicId} and t3.goods_source=2
|
</if>
|
<if test="query.supplierName != null and query.supplierName != ''">
|
and t4.supplier_name like concat('%',#{query.supplierName},'%')
|
</if>
|
|
<if test="query.typeId != null and query.typeId != ''">
|
and t3.type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t3.quasi_number =#{query.quasiNumber}
|
</if>
|
<if test="query.batchNumber != null and query.batchNumber != ''">
|
and t1.batch_number =#{query.batchNumber}
|
</if>
|
<if test="query.warehouseNo != null and query.warehouseNo != ''">
|
and t2.warehouse_no = #{query.warehouseNo}
|
</if>
|
GROUP BY t1.id
|
) as o
|
where (o.warehousing_number -o.outbound_count) >0
|
order by o.create_time desc
|
</select>
|
<select id="pageInventoryGoodsPageList1" resultType="com.ruoyi.system.vo.TErpGoodsInventoryVO">
|
select * from (
|
SELECT t1.id,t2.warehouse_no,
|
t3.goods_name,t3.goods_source,
|
case t3.goods_source when 1 then t4.supplier_name when 2 then t3.supplier_name end as supplierName,
|
t3.type_id,
|
t3.packing_unit_id,
|
t3.quasi_number,
|
t3.goods_id_code,
|
t1.batch_number,
|
coalesce(sum(t5.outbound_count),0) as outbound_count,
|
t1.warehousing_number,
|
t2.create_time,
|
t1.warehousing_number - coalesce(sum(t5.outbound_count),0) as num,
|
t1.unit_amount as unitAmount,
|
t1.sales_amount as salesAmount,
|
t1.expiry_date
|
from t_erp_clinic_warehousing_batch t1
|
LEFT JOIN t_erp_clinic_warehousing t2 on t1.warehousing_id = t2.id
|
LEFT JOIN t_erp_goods t3 on t1.goods_id = t3.id
|
LEFT JOIN t_crm_supplier t4 on t3.supplier_clinic_id = t4.id
|
LEFT JOIN t_erp_clinic_outbound_goods t5 on t5.warehousing_batch_id =t1.id
|
where t2.disabled = 0 and t2.clinic_id =#{supplierClinicId}
|
<if test="query.type != null and query.type ==1">
|
and #{time} > t1.expiry_date
|
</if>
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and t3.goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
<if test="query.supplierName != null and query.supplierName != ''">
|
and (t4.supplier_name like concat('%',#{query.supplierName},'%') or t3.supplier_name like concat('%',#{query.supplierName},'%'))
|
</if>
|
|
<if test="query.typeId != null and query.typeId != ''">
|
and t3.type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t3.quasi_number =#{query.quasiNumber}
|
</if>
|
<if test="query.batchNumber != null and query.batchNumber != ''">
|
and t1.batch_number =#{query.batchNumber}
|
</if>
|
<if test="query.warehouseNo != null and query.warehouseNo != ''">
|
and t2.warehouse_no = #{query.warehouseNo}
|
</if>
|
GROUP BY t1.id
|
) as o
|
where (o.warehousing_number -o.outbound_count) >0
|
order by o.create_time desc
|
</select>
|
<select id="pageInventoryGoodsList" resultType="com.ruoyi.system.vo.TErpGoodsInventoryVO">
|
select * from (
|
SELECT t1.id,t2.warehouse_no,
|
t3.goods_name,
|
t4.supplier_name,
|
t3.type_id,
|
t3.packing_unit_id,
|
t3.quasi_number,
|
t3.goods_id_code,
|
t1.batch_number,
|
coalesce(sum(t5.outbound_count),0) as outbound_count,
|
t1.warehousing_number,
|
t2.create_time,
|
t1.warehousing_number - coalesce(sum(t5.outbound_count),0) as num,
|
t2.unit_amount as sales_amount,
|
t1.expiry_date
|
from t_erp_supplier_warehousing_batch t1
|
LEFT JOIN t_erp_supplier_warehousing t2 on t1.warehousing_id = t2.id
|
LEFT JOIN t_erp_goods t3 on t2.goods_id = t3.id
|
LEFT JOIN t_crm_supplier t4 on t3.supplier_clinic_id = t4.id
|
LEFT JOIN t_erp_supplier_outbound_goods t5 on t5.warehousing_batch_id =t1.id
|
where t2.disabled = 0 and t2.warehouse_id = #{warehouseId}
|
and #{endDate} > t1.expiry_date
|
<if test="user.roleType !=null and user.roleType ==4">
|
and t3.supplier_clinic_id =#{supplierClinicId} and t3.goods_source=1
|
</if>
|
<if test="user.roleType !=null and user.roleType ==5">
|
and t3.supplier_clinic_id =#{supplierClinicId} and t3.goods_source=2
|
</if>
|
|
GROUP BY t1.id
|
) as o
|
where (o.warehousing_number -o.outbound_count) >0
|
order by o.create_time desc
|
</select>
|
<select id="pageInventoryGoodsList1" resultType="com.ruoyi.system.vo.TErpGoodsInventoryVO">
|
select * from (
|
SELECT t1.id,t2.warehouse_no,
|
t3.goods_name,
|
case t3.goods_source when 1 then t4.supplier_name when 2 then t3.supplier_name end as supplierName,
|
t3.type_id,
|
t3.packing_unit_id,
|
t3.quasi_number,
|
t3.goods_id_code,
|
t1.batch_number,
|
coalesce(sum(t5.outbound_count),0) as outbound_count,
|
t1.warehousing_number,
|
t2.create_time,
|
t1.warehousing_number - coalesce(sum(t5.outbound_count),0) as num,
|
t1.unit_amount as sales_amount,
|
t1.expiry_date
|
from t_erp_clinic_warehousing_batch t1
|
LEFT JOIN t_erp_clinic_warehousing t2 on t1.warehousing_id = t2.id
|
LEFT JOIN t_erp_goods t3 on t1.goods_id = t3.id
|
LEFT JOIN t_crm_supplier t4 on t3.supplier_clinic_id = t4.id
|
LEFT JOIN t_erp_clinic_outbound_goods t5 on t5.warehousing_batch_id =t1.id
|
where t2.disabled = 0
|
and #{endDate} > t1.expiry_date
|
<if test="user.roleType !=null and user.roleType ==4">
|
and t2.clinic_id =#{supplierClinicId}
|
</if>
|
<if test="user.roleType !=null and user.roleType ==5">
|
and t2.clinic_id =#{supplierClinicId}
|
</if>
|
|
GROUP BY t1.id
|
) as o
|
where o.num >0
|
order by o.create_time desc
|
</select>
|
<select id="getGoodsById" resultType="com.ruoyi.system.model.TErpGoods">
|
select <include refid="Base_Column_List"/> from t_erp_goods where id = #{goodsId}
|
</select>
|
<select id="pageAdminList" resultType="com.ruoyi.system.vo.TErpGoodsVO">
|
select
|
t1.id
|
, t1.supplier_clinic_id, t1.goods_source, t1.goods_name, t1.goods_id_code, t1.quasi_number,t1.manufacturer, t1.formulation_spec, t1.packing_spec, t1.type_id, t1.goods_yards,
|
t1.maintenance_interval,t1.maintenance_interval_unit, t1.low_purchase_quantity, t1.low_unit_id, t1.is_prescription_drug, t1.goods_spec, t1.warning_inventory,
|
t1.sales_amount, t1.packing_unit_id, t1.instructions_use, t1.side_effect, t1.clinic_purchase_price, t1.platform_commission_price, t1.create_time, t1.update_time, t1.create_by,
|
t1.`state`, t1.update_by, t1.disabled,
|
t1.simplified_code,
|
t1.dosage_form,
|
t1.usage_classification,
|
t1.product_brand,
|
t1.place_of_origin,
|
t1.ingredient,
|
t1.trait,
|
t1.indication,
|
t1.taboo,
|
t1.precautions,
|
t1.interaction,
|
t1.storage,
|
t2.supplier_name
|
from t_erp_goods t1 left join t_crm_supplier t2 on t1.supplier_clinic_id = t2.id and t1.goods_source =1
|
where t1.disabled = 0 and t1.goods_source =1
|
<if test="query.supplierName != null and query.supplierName != ''">
|
and t2.supplier_name like concat('%',#{query.supplierName},'%')
|
</if>
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and t1.goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
<if test="query.typeId != null and query.typeId != ''">
|
and t1.type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t1.quasi_number like concat('%',#{query.quasiNumber},'%')
|
</if>
|
<if test="query.state != null ">
|
and t1.state = #{query.state}
|
</if>
|
order by t1.create_time desc
|
</select>
|
<select id="pageAddList" resultType="com.ruoyi.system.model.TErpGoods">
|
SELECT t1.id,
|
t1.supplier_clinic_id,
|
t1.goods_source,
|
t1.goods_name,
|
t1.goods_id_code,
|
t1.quasi_number,
|
t1.manufacturer,
|
t1.formulation_spec,
|
t1.packing_spec,
|
t1.clinic_purchase_price,
|
t1.warning_inventory,
|
t1.type_id,
|
t1.goods_yards,
|
t1.maintenance_interval,
|
t1.maintenance_interval_unit,
|
t1.low_purchase_quantity,
|
t1.low_unit_id,
|
t1.is_prescription_drug,
|
t1.goods_spec,
|
t1.sales_amount,
|
t1.packing_unit_id,
|
t1.instructions_use,
|
t1.side_effect,
|
t1.platform_commission_price,
|
t1.state,
|
t1.simplified_code,
|
t1.dosage_form,
|
t1.usage_classification,
|
t1.product_brand,
|
t1.place_of_origin,
|
t1.ingredient,
|
t1.trait,
|
t1.indication,
|
t1.taboo,
|
t1.precautions,
|
t1.interaction,
|
t1.storage,
|
t1.barcode,
|
t2.supplier_name,
|
t1.clinic_ids,
|
t1.create_by,
|
t1.update_by,
|
t1.`disabled`,
|
t1.create_time,
|
t1.update_time,
|
t1.create_id,
|
t3.type_name
|
FROM t_erp_goods t1
|
LEFT JOIN t_crm_supplier t2 ON t1.supplier_clinic_id = t2.id
|
left join t_erp_goods_type t3 on t1.type_id = t3.id
|
WHERE t1.`disabled` = 0
|
AND (t1.goods_source = 1 AND t1.state = 1 AND t1.`disabled` = 0 AND t1.platform_commission_price IS NOT NULL)
|
and (NOT FIND_IN_SET(#{clinicSupplierId}, t1.clinic_ids) or t1.clinic_ids is null)
|
<if test="query.goodsName != null and query.goodsName != ''">
|
and t1.goods_name like concat('%',#{query.goodsName},'%')
|
</if>
|
<if test="query.typeId != null and query.typeId != ''">
|
and t1.type_id = #{query.typeId}
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t1.quasi_number like concat('%',#{query.quasiNumber},'%')
|
</if>
|
<if test="query.quasiNumber != null and query.quasiNumber != ''">
|
and t2.supplier_name like concat('%',#{query.supplierName},'%')
|
</if>
|
order by t1.create_time desc
|
|
|
</select>
|
|
</mapper>
|