aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-db/src/main/resources/org/sonar/db/source/SnapshotDataMapper.xml
blob: 022381e4df8d857fb656e43ed52ee637972c45bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?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.source.SnapshotDataMapper">

  <sql id="snapshotDataColumns">
    snapshot_id AS "snapshotId",
    snapshot_data AS "data",
    data_type AS "dataType"
  </sql>

  <select id="selectSnapshotData" parameterType="map" resultType="SnapshotData">
    SELECT
    <include refid="snapshotDataColumns"/>
    FROM snapshot_data
    WHERE snapshot_id = #{sid}
    AND data_type IN
    <foreach item="dataType" index="index" collection="dataTypes" open="(" separator="," close=")">#{dataType}</foreach>
  </select>

  <select id="selectSnapshotDataByComponentKey" parameterType="map" resultType="SnapshotData">
    SELECT
    <include refid="snapshotDataColumns"/>
    FROM snapshot_data sd
    INNER JOIN projects p ON p.id=sd.resource_id and p.enabled=${_true}
    WHERE p.kee = #{componentKey}
    AND data_type IN
    <foreach item="dataType" index="index" collection="dataTypes" open="(" separator="," close=")">#{dataType}</foreach>
  </select>

  <insert id="insert" parameterType="SnapshotData" useGeneratedKeys="false">
    insert into snapshot_data
    (resource_id, snapshot_id, snapshot_data, data_type, created_at, updated_at)
    values (
    #{resourceId,jdbcType=INTEGER}, #{snapshotId,jdbcType=INTEGER}, #{data,jdbcType=CLOB}, #{dataType,jdbcType=VARCHAR},
    CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)
  </insert>
</mapper>