OrderLogMapper.xml 3.08 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.b2c.orders.dao.impl.OrderLogDaoBean">
	<resultMap id="OrderLogRM" type="OrderLog">
		<id property="id" column="id" />
		<result property="action" column="action" />
		<result property="previousStatus" column="previous_status" />
		<result property="currentStatus" column="current_status" />
		<result property="actionTime" column="action_time" />
		<result property="userId" column="user_id" />
		<result property="userType" column="user_type" />
		<result property="orderId" column="order_id" />
		<result property="description" column="description" />
	</resultMap>

	<sql id="selectColumn">
		id
		,action
		,previous_status
		,current_status
		,action_time
		,user_id
		,user_type
		,order_id
		,description
	</sql>

	<sql id="selectCondition">
		<if test="param != null">
			<if test="param.id != null and param.id != ''">
				and id = #{param.id}
			</if>
			<if test="param.action != null and param.action != ''">
				and action = #{param.action}
			</if>
			<if test="param.previousStatus != null and param.previousStatus != ''">
				and action = #{param.previousStatus}
			</if>
			<if test="param.currentStatus != null and param.currentStatus != ''">
				and current_status = #{param.currentStatus}
			</if>
			<if test="param.actionBeginTime != null and param.actionBeginTime != ''">
				<![CDATA[and action_time >= #{param.actionBeginTime}]]>
			</if>
			<if test="param.actionEndTime != null and param.actionEndTime != ''">
				<![CDATA[and action_time <= #{param.actionEndTime}]]>
			</if>
			<if test="param.userId != null and param.userId != ''">
				and user_id = #{param.userId}
			</if>
			<if test="param.userType != null and param.userType != ''">
				and user_type = #{param.userType}
			</if>
		</if>
	</sql>

	<insert id="save" parameterType="OrderLog">
		<![CDATA[
			INSERT INTO t_order_log(
	                    id,
	                    action,
	                    previous_status,
	                    current_status,
	                    user_id,
	                    user_type,
	                    order_id,
	                    description
			) VALUES(
						#{id},
			        	#{action},
			        	#{previousStatus},
			        	#{currentStatus},
			        	#{userId},
			        	#{userType},
			        	#{orderId},
			        	#{description}
			)
		]]>
	</insert>


	<select id="findByOrderId" parameterType="Long" resultMap="OrderLogRM">
		SELECT
		<include refid="selectColumn" />
		FROM t_order_log where 1=1
		AND order_id = #{orderId}
		ORDER BY action_time DESC
	</select>

	<select id="countByCondition" parameterType="Query" resultType="Long">
		<![CDATA[
		SELECT count(1) FROM t_order_log where 1=1
		]]>
		<include refid="selectCondition" />
	</select>

	<select id="listByCondition" parameterType="Query" resultMap="OrderLogRM">
		SELECT
		<include refid="selectColumn" />
		FROM t_order_log where 1=1
		<include refid="selectCondition" />
		order by id desc
		<![CDATA[
		limit #{startRow},#{pageSize}
		]]>
	</select>

</mapper>