<?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.lyms.platform.permission.dao.slave.RolesMapper">

    <resultMap id="RolesResultMap" type="com.lyms.platform.permission.model.Roles">
        <id column="id" property="id" jdbcType="INTEGER"/>
        <result column="type" property="type" jdbcType="INTEGER"/>
        <result column="name" property="name" jdbcType="VARCHAR"/>
        <result column="publish_id" property="publishId" jdbcType="INTEGER"/>
        <result column="publish_name" property="publishName" jdbcType="VARCHAR"/>
        <result column="yn" property="yn" jdbcType="INTEGER"/>
        <result column="enable" property="enable" jdbcType="INTEGER"/>
        <result column="modified" property="modified" jdbcType="TIMESTAMP"/>
        <result column="created" property="created" jdbcType="TIMESTAMP"/>
        <result column="remarks" property="remarks" jdbcType="VARCHAR"/>
        <result column="shortCode" property="shortCode" jdbcType="VARCHAR"/>
        <result column="orgid" property="orgId" jdbcType="INTEGER"/>
    </resultMap>

    <insert id="addRoles" parameterType="com.lyms.platform.permission.model.Roles">
        <selectKey order="AFTER" keyProperty="id" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID() </selectKey>
insert into roles (type,name,publish_id,publish_name,yn,enable,modified,created,remarks,shortCode,orgid
        <if test="id != null and id >= 0">
            ,id
        </if>) values (#{type},#{name},#{publishId},#{publishName},#{yn},#{enable},#{modified},#{created},#{remarks},#{shortCode},#{orgId}
        <if test="id != null and id >= 0">
            ,#{id}
        </if>
        )
</insert>


    <update id="updateRoles" parameterType="com.lyms.platform.permission.model.Roles">
        update roles
        <set>
            <if test="type != null and type >= 0">
                type = #{type,jdbcType=INTEGER},
            </if>
            <if test="name != null and name != ''">
                name = #{name,jdbcType=VARCHAR},
            </if>
            <if test="publishId != null and publishId >= 0">
                publish_id = #{publishId,jdbcType=INTEGER},
            </if>
            <if test="permissiontype != null and permissiontype >= 0">
                permissiontype = #{permissiontype,jdbcType=INTEGER},
            </if>
            <if test="publishName != null and publishName != ''">
                publish_name = #{publishName,jdbcType=VARCHAR},
            </if>
            <if test="yn != null and yn >= 0">
                yn = #{yn,jdbcType=INTEGER},
            </if>
            <if test="enable != null and enable >= 0">
                enable = #{enable,jdbcType=INTEGER},
            </if>
            <if test="modified != null">
                modified = #{modified,jdbcType=TIMESTAMP},
            </if>
            <if test="created != null">
                created = #{created,jdbcType=TIMESTAMP},
            </if>
            <if test="remarks != null ">
                remarks = #{remarks,jdbcType=VARCHAR},
            </if>
            <if test="shortCode != null">
                shortCode = #{shortCode,jdbcType=VARCHAR},
            </if>
            <if test="orgId != null">
                orgid =#{orgId,jdbcType=INTEGER},
            </if>
        </set>
        where id = #{id,jdbcType=INTEGER}
    </update>


    <delete id="deleteRoles" parameterType="java.lang.Integer">
delete from roles where id = #{id,jdbcType=INTEGER}
</delete>


    <select id="getRoles" resultMap="RolesResultMap" parameterType="java.lang.Integer">
select id,type,name,publish_id,publish_name,yn,enable,modified,created,remarks,shortCode,orgid
 from roles where id = #{id,jdbcType=INTEGER}
</select>


    <sql id="orderAndLimit">
        <if test="sort != null and sort != '' ">
            order by ${sort}
            <if test="need != null">
                limit #{offset, jdbcType=INTEGER} , #{limit, jdbcType=INTEGER}
            </if>
        </if>
    </sql>


    <sql id="RolesCondition">
        <where>
            1 = 1
            <if test="id != null and id >= 0">
                and id = #{id,jdbcType=INTEGER}
            </if>
            <if test="type != null and type >= 0">
                and type = #{type,jdbcType=INTEGER}
            </if>
            <if test="name != null and name != ''">
                and name = #{name,jdbcType=VARCHAR}
            </if>
            <if test="publishId != null and publishId >= 0">
                and publish_id = #{publishId,jdbcType=INTEGER}
            </if>
            <if test="publishName != null and publishName != ''">
                and publish_name = #{publishName,jdbcType=VARCHAR}
            </if>
            <if test="yn != null and yn >= 0">
                and yn = #{yn,jdbcType=INTEGER}
            </if>
            <if test="enable != null and enable >= 0">
                and enable = #{enable,jdbcType=INTEGER}
            </if>
            <if test="modified != null">
                and modified = #{modified,jdbcType=TIMESTAMP}
            </if>
            <if test="created != null">
                and created = #{created,jdbcType=TIMESTAMP}
            </if>
            <if test="remarks != null and remarks != ''">
                and remarks = #{remarks,jdbcType=VARCHAR}
            </if>
            <if test="shortCode != null and shortCode != ''">
                and shortCode = #{shortCode,jdbcType=VARCHAR}
            </if>
            <if test="orgIds !=null  and orgIds.size() >0">
                and orgId in
                <foreach collection="orgIds" index="index" item="item" open="(" separator="," close=")">
                    #{item}
                </foreach>
            </if>
            <if test="keyword != null and keyword != ''">
                and name like CONCAT(#{keyword}, '%')
            </if>
        </where>
    </sql>


    <select id="queryRoles" resultMap="RolesResultMap" parameterType="com.lyms.platform.permission.model.RolesQuery">
        select id,type,name,publish_id,publish_name,yn,enable,modified,created,remarks,shortCode,permissiontype
        from roles
        <include refid="RolesCondition"/>
        <include refid="orderAndLimit"/>
    </select>


    <select id="queryRolesCount" resultType="int" parameterType="com.lyms.platform.permission.model.RolesQuery">
        select count(1) from roles
        <include refid="RolesCondition"/>
    </select>


</mapper>