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

org.sonar.db.purge.PurgeMapper.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.purge.PurgeMapper">

  <select id="selectSnapshotIds" parameterType="map" resultType="long">
    select s.id from snapshots s
    <where>
      <if test="islast != null">
        and s.islast=#{islast}
      </if>
      <if test="notPurged != null and notPurged">
        and (s.purge_status is null or s.purge_status=0)
      </if>
      <if test="rootSnapshotId != null">
        and s.root_snapshot_id=#{rootSnapshotId}
      </if>
      <if test="id != null">
        and s.id=#{id}
      </if>
      <if test="rootProjectId != null">
        and s.root_project_id=#{rootProjectId}
      </if>
      <if test="resourceId != null">
        and s.project_id=#{resourceId}
      </if>
      <if test="status != null">
        and s.status in
        <foreach item="s" index="index" collection="status" open="(" separator="," close=")">#{s}</foreach>
      </if>
      <if test="scopes != null">
        and s.scope in
        <foreach item="scope" index="index" collection="scopes" open="(" separator="," close=")">#{scope}</foreach>
      </if>
      <if test="qualifiers != null">
        and s.qualifier in
        <foreach item="qualifier" index="index" collection="qualifiers" open="(" separator="," close=")">#{qualifier}
        </foreach>
      </if>
      <if test="withVersionEvent != null">
        <if test="withVersionEvent">
          and exists(select e.id from events e where e.snapshot_id=s.id and e.category='Version')
        </if>
        <if test="!withVersionEvent">
          and not exists(select e.id from events e where e.snapshot_id=s.id and e.category='Version')
        </if>
      </if>
    </where>
  </select>

  <select id="selectSnapshotIdsByResource" parameterType="map" resultType="long">
    select s.id from snapshots s
    <where>
      s.project_id in
      <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
        #{resourceId}
      </foreach>
    </where>
  </select>

  <select id="selectPurgeableSnapshotsWithEvents" parameterType="long" resultType="PurgeableSnapshot">
    select s.id as "snapshotId", s.created_at as "date", ${_true} as "hasEvents", islast as "isLast" from
    snapshots s where
    s.project_id=#{id} and s.status='P' and s.qualifier &lt;&gt; 'LIB' and
    exists(select e.id from events e where e.snapshot_id=s.id)
  </select>

  <select id="selectPurgeableSnapshotsWithoutEvents" parameterType="long" resultType="PurgeableSnapshot">
    select s.id as "snapshotId", s.created_at as "date", ${_false} as "hasEvents", islast as "isLast" from
    snapshots s where
    s.project_id=#{id} and s.status='P' and s.qualifier &lt;&gt; 'LIB' and
    not exists(select e.id from events e where e.snapshot_id=s.id)
  </select>

  <select id="selectComponentIdUuidsToDisable" resultType="org.sonar.db.purge.IdUuidPair" parameterType="long">
    select p.id, p.uuid from projects p
    where (p.id=#{id} or p.root_id=#{id}) and p.enabled=${_true}
    and not exists(select s.project_id from snapshots s where s.islast=${_true} and s.project_id=p.id)
  </select>

  <select id="selectMetricIdsWithoutHistoricalData" resultType="long">
    select id from metrics where delete_historical_data=${_true}
  </select>

  <select id="selectComponentsByProjectUuid" resultType="org.sonar.db.purge.IdUuidPair" parameterType="String">
    select id, uuid from projects where project_uuid=#{uuid} or uuid=#{uuid}
  </select>

  <delete id="deleteSnapshotMeasures" parameterType="map">
    delete from project_measures where snapshot_id in
    <foreach collection="snapshotIds" open="(" close=")" item="snapshotId" separator=",">
      #{snapshotId}
    </foreach>
  </delete>

  <delete id="deleteSnapshotDuplications" parameterType="map">
    delete from duplications_index where snapshot_id in
    <foreach collection="snapshotIds" open="(" close=")" item="snapshotId" separator=",">
      #{snapshotId}
    </foreach>
  </delete>

  <delete id="deleteSnapshotEvents" parameterType="map">
    delete from events where snapshot_id in
    <foreach collection="snapshotIds" open="(" close=")" item="snapshotId" separator=",">
      #{snapshotId}
    </foreach>
  </delete>

  <delete id="deleteSnapshot" parameterType="map">
    delete from snapshots where id in
    <foreach collection="snapshotIds" open="(" close=")" item="snapshotId" separator=",">
      #{snapshotId}
    </foreach>
  </delete>

  <delete id="deleteSnapshotWastedMeasures" parameterType="map">
    delete from project_measures
    <where>
      snapshot_id in
      <foreach collection="snapshotIds" open="(" close=")" item="snapshotId" separator=",">
        #{snapshotId}
      </foreach>
      and (person_id is not null
      <if test="mids.size()>0">
        or metric_id in
        <foreach item="mid" index="index" collection="mids" open="(" separator="," close=")">#{mid}</foreach>
      </if>
      )
    </where>
  </delete>

  <update id="updatePurgeStatusToOne" parameterType="long">
    update snapshots set purge_status = 1 where id = #{id}
  </update>

  <update id="disableResource" parameterType="long">
    update projects set enabled=${_false} where id=#{id}
  </update>

  <update id="resolveResourceIssuesNotAlreadyResolved" parameterType="map">
    UPDATE issues SET status='CLOSED',resolution='REMOVED',updated_at=#{dateAsLong},issue_close_date=#{dateAsLong},
    issue_update_date=#{dateAsLong}
    WHERE component_uuid=#{componentUuid} AND resolution IS NULL
  </update>

  <delete id="deleteResourceIndex" parameterType="map">
    delete from resource_index where resource_id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteEvent" parameterType="map">
    delete from events where id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteResourceLinks" parameterType="map">
    delete from project_links where component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <delete id="deleteResourceProperties" parameterType="map">
    delete from properties where resource_id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteResource" parameterType="map">
    delete from projects where id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteResourceGroupRoles" parameterType="map">
    delete from group_roles where resource_id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteResourceUserRoles" parameterType="map">
    delete from user_roles where resource_id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <delete id="deleteResourceManualMeasures" parameterType="map">
    delete from manual_measures where component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <delete id="deleteComponentEvents" parameterType="map">
    delete from events where component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <delete id="deleteAuthors" parameterType="map">
    delete from authors where person_id in
    <foreach collection="resourceIds" open="(" close=")" item="resourceId" separator=",">
      #{resourceId}
    </foreach>
  </delete>

  <update id="setSnapshotIsLastToFalse" parameterType="long">
    update snapshots set islast=${_false} where project_id=#{id}
  </update>

  <delete id="deleteComponentIssueChanges" parameterType="map">
    delete from issue_changes ic
    where exists (select * from issues i where i.kee=ic.issue_key and i.component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
    )
  </delete>

  <!-- Mssql -->
  <delete id="deleteComponentIssueChanges" databaseId="mssql" parameterType="map">
    delete issue_changes from issue_changes
    inner join issues on issue_changes.issue_key=issues.kee
    where issues.component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <!-- Mysql -->
  <delete id="deleteComponentIssueChanges" databaseId="mysql" parameterType="map">
    delete ic from issue_changes as ic, issues as i where ic.issue_key=i.kee and i.component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <delete id="deleteComponentIssues" parameterType="map">
    delete from issues where component_uuid in
    <foreach collection="componentUuids" open="(" close=")" item="componentUuid" separator=",">
      #{componentUuid}
    </foreach>
  </delete>

  <delete id="deleteFileSourcesByProjectUuid">
    delete from file_sources where project_uuid=#{rootProjectUuid}
  </delete>

  <delete id="deleteFileSourcesByUuid">
    delete from file_sources where file_uuid=#{fileUuid}
  </delete>

  <select id="selectOldClosedIssueKeys" parameterType="map" resultType="String">
    SELECT kee FROM issues
    WHERE project_uuid=#{projectUuid}
    <choose>
      <when test="toDate == null">
        AND issue_close_date IS NOT NULL
      </when>
      <otherwise>
        AND issue_close_date &lt; #{toDate}
      </otherwise>
    </choose>
  </select>

  <delete id="deleteIssuesFromKeys" parameterType="map">
    DELETE FROM issues
    WHERE kee IN
    <foreach collection="keys" open="(" close=")" item="key" separator=",">
      #{key}
    </foreach>
  </delete>

  <delete id="deleteIssueChangesFromIssueKeys" parameterType="map">
    DELETE FROM issue_changes
    WHERE issue_key IN
    <foreach collection="issueKeys" open="(" close=")" item="issueKey" separator=",">
      #{issueKey}
    </foreach>
  </delete>

  <delete id="deleteCeActivityByProjectUuid">
      delete from ce_activity where component_uuid=#{rootProjectUuid}
  </delete>

</mapper>





© 2015 - 2025 Weber Informatics LLC | Privacy Policy