All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.db.user.GroupMapper.xml Maven / Gradle / Ivy

<?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="org.sonar.db.user.GroupMapper">

  <sql id="groupColumns">
    g.id as id,
    g.name as name,
    g.description as description,
    g.created_at as "createdAt",
    g.updated_at as "updatedAt"
  </sql>

  <select id="selectByKey" parameterType="string" resultType="Group">
    SELECT
    <include refid="groupColumns"/>
    FROM groups g
    <where>
      g.name=#{id}
    </where>
  </select>

  <select id="selectById" parameterType="long" resultType="Group">
    SELECT
    <include refid="groupColumns"/>
    FROM groups g
    <where>
      g.id=#{id}
    </where>
  </select>

  <delete id="deleteById" parameterType="long">
    DELETE FROM groups
    <where>
      id=#{id}
    </where>
  </delete>

  <select id="selectByUserLogin" parameterType="string" resultType="Group">
    SELECT
    <include refid="groupColumns"/>
    FROM groups g
    INNER JOIN groups_users gu on gu.group_id=g.id
    INNER JOIN users u on u.id=gu.user_id
    <where>
      u.login=#{login}
    </where>
  </select>

  <select id="selectByNames" parameterType="map" resultType="Group">
    SELECT
    <include refid="groupColumns"/>
    FROM groups g
    <where>
      g.name IN
      <foreach item="name" index="index" collection="names" open="(" separator="," close=")">
        #{name}
      </foreach>
    </where>
  </select>

  <insert id="insert" parameterType="Group" keyColumn="id" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO groups (name, description, created_at, updated_at)
    VALUES (#{name}, #{description}, #{createdAt}, #{updatedAt})
  </insert>

  <update id="update" parameterType="Group">
    UPDATE groups SET
    name=#{name},
    description=#{description},
    updated_at=#{updatedAt}
    WHERE id=#{id}
  </update>

  <select id="selectByQuery" parameterType="map" resultType="Group">
    SELECT
    <include refid="groupColumns"/>
    FROM groups g
    <where>
      <if test="query!=null">
        UPPER(g.name) LIKE #{query} ESCAPE '/'
      </if>
    </where>
    ORDER BY UPPER(g.name)
  </select>

  <select id="countByQuery" parameterType="map" resultType="int">
    SELECT count(1)
    FROM groups g
    <where>
      <if test="query!=null">
        UPPER(g.name) LIKE #{query} ESCAPE '/'
      </if>
    </where>
  </select>
</mapper>




© 2015 - 2025 Weber Informatics LLC | Privacy Policy