ExpressInfoMapper.xml 4.02 KB
<?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.yohoufo.dal.order.ExpressInfoMapper">
  <resultMap id="BaseResultMap" type="com.yohoufo.dal.order.model.ExpressInfo">
    <id column="id" jdbcType="INTEGER" property="id" />
    <result column="uid" jdbcType="INTEGER" property="uid" />
    <result column="order_code" jdbcType="BIGINT" property="orderCode" />
    <result column="waybill_code" jdbcType="VARCHAR" property="waybillCode" />
    <result column="accept_address" jdbcType="VARCHAR" property="acceptAddress" />
    <result column="accept_remark" jdbcType="VARCHAR" property="acceptRemark" />
    <result column="logistics_type" jdbcType="INTEGER" property="logisticsType" />
    <result column="create_time" jdbcType="INTEGER" property="createTime" />
    <result column="express_type" jdbcType="TINYINT" property="expressType" />
    <result column="state" jdbcType="INTEGER" property="state" />
    <result column="data_type" jdbcType="INTEGER" property="dataType" />
    <result column="operate_transfer_code" jdbcType="INTEGER" property="operateTransferCode" />
  </resultMap>
  <sql id="Base_Column_List">
    id, uid, order_code, waybill_code, accept_address, accept_remark, logistics_type, 
    create_time, express_type, state,data_type,operate_transfer_code
  </sql>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select 
    <include refid="Base_Column_List" />
    from express_info
    where id = #{id,jdbcType=INTEGER}
  </select>
  <!--
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    delete from express_info
    where id = #{id,jdbcType=INTEGER}
  </delete>
  -->
  <insert id="insert" keyColumn="id" keyProperty="id" parameterType="com.yohoufo.dal.order.model.ExpressInfo" useGeneratedKeys="true">
    insert into express_info (uid, order_code, waybill_code, 
      accept_address, accept_remark, logistics_type, 
      create_time, express_type, state,data_type,operate_transfer_code
      )
    values (#{uid,jdbcType=INTEGER}, #{orderCode,jdbcType=BIGINT}, #{waybillCode,jdbcType=VARCHAR}, 
      #{acceptAddress,jdbcType=VARCHAR}, #{acceptRemark,jdbcType=VARCHAR}, #{logisticsType,jdbcType=INTEGER}, 
      #{createTime,jdbcType=INTEGER}, #{expressType,jdbcType=TINYINT}, #{state,jdbcType=INTEGER}
      , #{dataType,jdbcType=INTEGER}, #{operateTransferCode,jdbcType=INTEGER}
      )
  </insert>


  <select id="selectByOrderCodeAndExpressType" resultMap="BaseResultMap">
    SELECT <include refid="Base_Column_List" />
    FROM express_info
    where  order_code = #{orderCode} and express_type = #{expressType}
    ORDER BY data_type , create_time DESC ,id DESC
  </select>

  <select id="selectByOrderCodeAndOperateTransferCode" resultMap="BaseResultMap">
    SELECT <include refid="Base_Column_List" />
    FROM express_info
    where  order_code = #{orderCode} and operate_transfer_code = #{operateTransferCode}
  </select>

  <select id="selectExpressInfoListByWaybillCodeAndLogisticsType" resultMap="BaseResultMap">
    SELECT <include refid="Base_Column_List" />
    FROM express_info
    where waybill_code = #{waybillCode} and logistics_type = #{logisticsType}
    ORDER BY create_time DESC
  </select>


  <select id="selectLast" resultMap="BaseResultMap">
    SELECT <include refid="Base_Column_List" />
    FROM express_info
    where order_code = #{orderCode} and express_type = #{expressType}
    ORDER BY create_time DESC
    limit 1
  </select>

  <select id="selectByOrderCodeAndStatesAndUidAndExpressType" resultMap="BaseResultMap">
    SELECT <include refid="Base_Column_List" />
    FROM express_info
    where uid = #{uid} and order_code = #{orderCode} and express_type = #{expressType} and state in
    <foreach collection="states" item="state" separator="," open="(" close=")" >
       #{state,jdbcType=INTEGER}
    </foreach>
    ORDER BY create_time DESC
  </select>
</mapper>