RoleDataPermissionDao.xml 4.0 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.tianbo.warehouse.dao.RoleDataPermissionDao">
  <resultMap id="BaseResultMap" type="com.tianbo.warehouse.model.RoleDataPermission">
    <id column="id" jdbcType="INTEGER" property="id" />
    <result column="role_id" jdbcType="INTEGER" property="roleId" />
    <result column="permission_id" jdbcType="INTEGER" property="permissionId" />
  </resultMap>
  <resultMap id="PermissionResultMap" type="com.tianbo.warehouse.model.RoleDataPermission" extends="BaseResultMap">
    <collection javaType="java.util.ArrayList" ofType="com.tianbo.warehouse.model.DataPermission" property="dataPermissions">
      <result column="data_perm_id" jdbcType="INTEGER" property="data_perm_id" />
      <result column="perm_name" jdbcType="VARCHAR" property="perm_name" />
    </collection>
  </resultMap>
  <sql id="Base_Column_List">
    id, role_id, permission_id
  </sql>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select
    <include refid="Base_Column_List" />
    from role_data_permission
    where id = #{id,jdbcType=INTEGER}
  </select>
  <select id="getRoleDataPerms" parameterType="java.lang.Integer" resultMap="PermissionResultMap">
    SELECT
      t.id,
      t.role_id,
      t.permission_id,
      dp.data_perm_id,
      dp.perm_name
    FROM
      (
      SELECT
          id,
          role_id,
          permission_id
      FROM
          role_data_permission rdp
      WHERE
          role_id = #{roleId,jdbcType=INTEGER}
      ) t
      LEFT JOIN data_permission dp
      ON t.permission_id = dp.data_perm_id
	ORDER BY dp.perm_keyword,dp.perm_sort
  </select>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    delete from role_data_permission
    where id = #{id,jdbcType=INTEGER}
  </delete>
  <delete id="delPermByRoleId" parameterType="java.lang.Integer">
    delete from role_data_permission
    where role_id = #{roleId,jdbcType=INTEGER}
  </delete>

  <insert id="insertRoleDataPerm" parameterType="com.tianbo.warehouse.model.RoleDataPermission">
    insert into role_data_permission(role_id, permission_id)
    values
    <foreach collection="permissionIds" item="rolePem" index="index"  separator=",">
      <if test="rolePem !=null">
        (#{roleId,jdbcType=INTEGER},#{rolePem,jdbcType=INTEGER})
      </if>
    </foreach>
  </insert>
  <insert id="insert" keyColumn="id" keyProperty="id" parameterType="com.tianbo.warehouse.model.RoleDataPermission" useGeneratedKeys="true">
    insert into role_data_permission (role_id, permission_id)
    values (#{roleId,jdbcType=INTEGER}, #{permissionId,jdbcType=INTEGER})
  </insert>
  <insert id="insertSelective" keyColumn="id" keyProperty="id" parameterType="com.tianbo.warehouse.model.RoleDataPermission" useGeneratedKeys="true">
    insert into role_data_permission
    <trim prefix="(" suffix=")" suffixOverrides=",">
      <if test="roleId != null">
        role_id,
      </if>
      <if test="permissionId != null">
        permission_id,
      </if>
    </trim>
    <trim prefix="values (" suffix=")" suffixOverrides=",">
      <if test="roleId != null">
        #{roleId,jdbcType=INTEGER},
      </if>
      <if test="permissionId != null">
        #{permissionId,jdbcType=INTEGER},
      </if>
    </trim>
  </insert>
  <update id="updateByPrimaryKeySelective" parameterType="com.tianbo.warehouse.model.RoleDataPermission">
    update role_data_permission
    <set>
      <if test="roleId != null">
        role_id = #{roleId,jdbcType=INTEGER},
      </if>
      <if test="permissionId != null">
        permission_id = #{permissionId,jdbcType=INTEGER},
      </if>
    </set>
    where id = #{id,jdbcType=INTEGER}
  </update>
  <update id="updateByPrimaryKey" parameterType="com.tianbo.warehouse.model.RoleDataPermission">
    update role_data_permission
    set role_id = #{roleId,jdbcType=INTEGER},
      permission_id = #{permissionId,jdbcType=INTEGER}
    where id = #{id,jdbcType=INTEGER}
  </update>
</mapper>