<?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="cn.wisenergy.mapper.StaffMapper">
    <resultMap id="staffMap" type="cn.wisenergy.model.app.Staff">
        <id column="id" property="id"></id>
        <result column="staff_name" property="staffName"/>
        <result column="login_name" property="loginName"/>
        <result column="password" property="password"/>
        <result column="phone" property="phone"/>
        <result column="is_delete" property="isDelete"/>
        <result column="create_time" property="createTime"/>
        <result column="update_time" property="updateTime"/>
        <result column="sex" property="sex"/>
    </resultMap>

    <sql id="table">
        staff
    </sql>

    <sql id="cols_all">
        id,
        <include refid="cols_exclude_id"/>
    </sql>

    <sql id="cols_exclude_id">
        staff_name,login_name,password, phone,is_delete,create_time,update_time,sex
    </sql>

    <sql id="vals">
        #{staffName},#{loginName},#{password},#{phone},
        #{isDelete},now(),now(),#{sex}
    </sql>

    <sql id="updateCondition">
        <if test="staffName != null">staff_name = #{staffName},</if>
        <if test="loginName !=null">login_name = #{loginName},</if>
        <if test="password != null">password =#{password},</if>
        <if test="phone != null">phone =#{phone},</if>
        <if test="isDelete != null">is_delete = #{isDelete},</if>
        <if test="sex != null">sex = #{sex},</if>
        update_time =now()
    </sql>

    <sql id="criteria">
        <if test="id != null">id = #{id}</if>
        <if test="staffName != null">and staff_name = #{staffName}</if>
        <if test="loginName !=null">and login_name = #{login_name}</if>
        <if test="password != null">and password =#{password}</if>
        <if test="phone != null">and phone =#{phone}</if>
        <if test="isDelete != null">and is_delete = #{isDelete}</if>
        <if test="createTime != null">and create_time &gt;= #{createTime}</if>
        <if test="updateTime != null">and #{updateTime} &gt;= update_time</if>
        <if test="sex != null">sex = #{sex}</if>
    </sql>

    <insert id="addStaff" parameterType="cn.wisenergy.model.app.Staff">
        insert into
        <include refid="table"/>
        (<include refid="cols_exclude_id"/>)
        value(
        <include refid="vals"/>
        )
    </insert>

    <update id="editStaff" parameterType="cn.wisenergy.model.app.Staff">
        UPDATE
        <include refid="table"/>
        <set>
            <include refid="updateCondition"/>
        </set>
        <where>
            id = #{id}
        </where>
    </update>

    <select id="getStaffList" resultMap="staffMap" parameterType="map">
        select
        <include refid="cols_all"/>
        from
        <include refid="table"/>
        <where>
            1=1
            <if test="staffName != null">and staff_name like ('%' #{staffName} '%')</if>

            <if test="phone != null">and phone like ('%' #{phone} '%')</if>
            order by is_delete,create_time desc
            <if test="pageNo != null">
                limit #{pageNo},#{pageSize}
            </if>
        </where>
    </select>

    <select id="getStaffListCount" resultType="java.lang.Integer" parameterType="map">
        select
        count(1)
        from
        <include refid="table"/>
        <where>
            1=1
            <if test="staffName != null and staffName !=''">and staff_name like ('%' #{staffName} '%')</if>

            <if test="phone != null and phone !=''">and phone like ('%' #{phone} '%')</if>

        </where>
    </select>

    <update id="delete" parameterType="int">
        UPDATE
        <include refid="table"/>
        <set>
             is_delete = 1
        </set>
        <where>
            id = #{id}
        </where>

    </update>

    <select id="getById" resultMap="staffMap">
        select
        <include refid="cols_all"/>
        from
        <include refid="table"/>
        <where>id = #{id}</where>
    </select>

    <select id="getUserNumbers" resultType="java.lang.Integer">
        SELECT COUNT(id)
        FROM
        <include refid="table"/>
        <where>
            is_delete=0

            <if test="staffName != null">and staff_name like ('%' #{staffName} '%')</if>

            <if test="phone != null">and phone like ('%' #{phone} '%')</if>
        </where>

    </select>

    <select id="getStaff" resultMap="staffMap" parameterType="map">
        select
        <include refid="cols_all"/>
        from
        <include refid="table"/>
        <where>
            login_name=#{loginName}
        </where>
    </select>
</mapper>