Welcome to mirror list, hosted at ThFree Co, Russian Federation.

date_time.rb « database « gitlab « lib - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: b6a89f715fdaaa725a5546682d165c2beac28128 (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
module Gitlab
  module Database
    module DateTime
      # Find the first of the `end_time_attrs` that isn't `NULL`. Subtract from it
      # the first of the `start_time_attrs` that isn't NULL. `SELECT` the resulting interval
      # along with an alias specified by the `as` parameter.
      #
      # Note: For MySQL, the interval is returned in seconds.
      #       For PostgreSQL, the interval is returned as an INTERVAL type.
      def subtract_datetimes(query_so_far, end_time_attrs, start_time_attrs, as)
        diff_fn = if Gitlab::Database.postgresql?
                    Arel::Nodes::Subtraction.new(
                      Arel::Nodes::NamedFunction.new("COALESCE", Array.wrap(end_time_attrs)),
                      Arel::Nodes::NamedFunction.new("COALESCE", Array.wrap(start_time_attrs)))
                  elsif Gitlab::Database.mysql?
                    Arel::Nodes::NamedFunction.new(
                      "TIMESTAMPDIFF",
                      [Arel.sql('second'),
                       Arel::Nodes::NamedFunction.new("COALESCE", Array.wrap(start_time_attrs)),
                       Arel::Nodes::NamedFunction.new("COALESCE", Array.wrap(end_time_attrs))])
                  end

        query_so_far.project(diff_fn.as(as))
      end
    end
  end
end