<?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.nanometer.smartlab.dao.SysWarehouseDao">
|
<resultMap id="SysWarehouse" type="com.nanometer.smartlab.entity.SysWarehouse">
|
<id property="id" column="id"/>
|
<result property="type" column="type"></result>
|
<result property="name" column="name"></result>
|
<result property="infoCode" column="info_code"></result>
|
<result property="barCode" column="bar_code"></result>
|
<result property="location1" column="location1"></result>
|
<result property="location2" column="location2"></result>
|
<result property="validFlag" column="valid_flag" typeHandler="com.nanometer.smartlab.entity.handler.ValidFlagHandler"></result>
|
<result property="createTime" column="create_time"></result>
|
<result property="updateTime" column="update_time"></result>
|
<result property="department" column="department"></result>
|
<result property="temperatureMax" column="temperature_max"></result>
|
<result property="temperatureMin" column="temperature_min"></result>
|
<result property="humidityMax" column="humidity_max"></result>
|
<result property="humidityMin" column="humidity_min"></result>
|
</resultMap>
|
|
<resultMap id="SysWarehouseDto" type="com.nanometer.smartlab.entity.dto.SysWarehouseDto">
|
<id property="id" column="id"/>
|
<result property="type" column="type"/>
|
<result property="name" column="name"/>
|
<result property="infoCode" column="info_code"/>
|
<result property="barCode" column="bar_code"/>
|
<result property="location1" column="location1"/>
|
<result property="location2" column="location2"/>
|
<collection property="sysWarehouseContainer" ofType="com.nanometer.smartlab.entity.dto.SysWarehouseContainerDto" fetchType="lazy">
|
<id property="id" column="wc_id"/>
|
<result property="type" column="wc_type"/>
|
<result property="name" column="wc_name"/>
|
<result property="containerCode" column="container_code"/>
|
<result property="infoCode" column="info_code"/>
|
<result property="structure" column="structure"/>
|
<result property="warehouseContainerName" column="wc_name"/>
|
<result property="warehouseContainerType" column="wc_type"/>
|
<result property="controllerCode" column="controller_code"/>
|
</collection>
|
</resultMap>
|
|
<sql id="queryWhereSql">
|
<if test="type != null and type != ''">
|
and su.type = #{type}
|
</if>
|
<if test="name != null and name != ''">
|
and su.name like #{name}
|
</if>
|
<if test="barCode != null and barCode != ''">
|
and su.bar_code = #{barCode}
|
</if>
|
<if test="editId != null and editId != ''">
|
and su.id != #{editId}
|
</if>
|
</sql>
|
|
<select id="getSysWarehouse" resultMap="SysWarehouse" >
|
select * from sys_warehouse
|
where id = #{id} and valid_flag = 1
|
</select>
|
|
<select id="getSysWarehouseList" parameterType="java.util.Map" resultMap="SysWarehouse">
|
select su.* from sys_warehouse as su
|
where su.valid_flag = 1
|
<include refid="queryWhereSql"/>
|
order by su.type ASC
|
<if test="first != null and pageSize != null">
|
limit #{first}, #{pageSize}
|
</if>
|
</select>
|
|
<select id="getSysWarehouseTotalCount" parameterType="java.util.Map" resultType="int">
|
select count(1) from sys_warehouse as su
|
where su.valid_flag = 1
|
<include refid="queryWhereSql"/>
|
</select>
|
|
<select id="getAllSysWarehouseList" resultMap="SysWarehouse">
|
select * from sys_warehouse
|
where valid_flag = 1
|
order by name asc
|
</select>
|
|
<insert id="insertSysWarehouse" parameterType="com.nanometer.smartlab.entity.SysWarehouse" useGeneratedKeys = "true" keyProperty = "id">
|
insert into sys_warehouse( type, name, info_code, bar_code, location1, location2, valid_flag, create_time, update_time,department,temperature_max,temperature_min,humidity_max,humidity_min)
|
values ( #{type}, #{name}, #{infoCode}, #{barCode}, #{location1}, #{location2}, 1, now(), now(),#{department},#{temperatureMax},#{temperatureMin},#{humidityMax},#{humidityMin})
|
</insert>
|
|
<update id="updateSysWarehouse" parameterType="com.nanometer.smartlab.entity.SysWarehouse">
|
update sys_warehouse set type=#{type}, name=#{name}, info_code=#{infoCode}, bar_code=#{barCode}, location1=#{location1}, location2=#{location2},
|
update_time=now(),department=#{department}
|
,temperature_max = #{temperatureMax}
|
,temperature_min = #{temperatureMin}
|
,humidity_max = #{humidityMax}
|
,humidity_min = #{humidityMin}
|
where id=#{id}
|
</update>
|
|
<update id="deleteSysWarehouses" parameterType="java.util.List">
|
update sys_warehouse set valid_flag=0, update_time=now()
|
where id in
|
<foreach collection="list" item="item" index="index" open="(" separator="," close=")">
|
#{item}
|
</foreach>
|
</update>
|
|
<select id="getSysWarehouseByBarCode" resultMap="SysWarehouse" >
|
select * from sys_warehouse
|
where bar_code = #{barCode}
|
</select>
|
|
|
<select id="selectWarehouse" resultMap="SysWarehouseDto">
|
SELECT
|
sw.id,
|
bm1.meta_value type,
|
sw.`name` name ,
|
sw.info_code,
|
sw.bar_code,
|
sw.location1,
|
sw.location2,
|
swc.id wc_id,
|
bm2.meta_value wc_type,
|
swc.`name` wc_name,
|
swc.info_code ,
|
swc.controller_code,
|
bm3.meta_value structure,
|
swc.container_code
|
FROM
|
`sys_warehouse` sw
|
LEFT JOIN base_meta bm1 ON bm1.id = sw.type
|
LEFT JOIN sys_warehouse_container swc ON swc.warehouse_id = sw.id
|
LEFT JOIN base_meta bm2 ON bm2.id = swc.type
|
LEFT JOIN base_meta bm3 ON bm3.id = swc.structure
|
where sw.valid_flag = 1
|
AND swc.valid_flag = 1
|
</select>
|
<select id="selectAllWarehouse" resultType="java.util.Map">
|
select
|
sw.id,
|
sw.type,
|
bm.meta_value typeName,
|
sw.name,
|
sw.info_code infoCode,
|
sw.bar_code barCode,
|
sw.location1,
|
sw.location2,
|
date_format(sw.create_time,'%Y-%m-%d %H:%i:%S') createTime,
|
sw.department
|
from sys_warehouse as sw
|
left join base_meta bm on bm.id = sw.type
|
where sw.valid_flag = 1
|
</select>
|
</mapper>
|