<?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.master.MasterRolesMapper">
<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,orgid
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>