summaryrefslogtreecommitdiffstats
path: root/app/models/query.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2011-07-09 21:34:35 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2011-07-09 21:34:35 +0000
commit4a4a71349a45bdc8a55071e535bc0a8b9c02a5ee (patch)
tree8dfd8a7b8af0fd85485ac62607726f186f437277 /app/models/query.rb
parentc7c062a981f14b256eb19a68664b08f21e5e8cc7 (diff)
downloadredmine-4a4a71349a45bdc8a55071e535bc0a8b9c02a5ee.tar.gz
redmine-4a4a71349a45bdc8a55071e535bc0a8b9c02a5ee.zip
Fixes "less than", "greater than" filters on custom fields with postgres (#6180).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@6216 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/query.rb')
-rw-r--r--app/models/query.rb12
1 files changed, 10 insertions, 2 deletions
diff --git a/app/models/query.rb b/app/models/query.rb
index 2b0776cbe..165bbac84 100644
--- a/app/models/query.rb
+++ b/app/models/query.rb
@@ -616,9 +616,17 @@ class Query < ActiveRecord::Base
sql = "#{db_table}.#{db_field} IS NOT NULL"
sql << " AND #{db_table}.#{db_field} <> ''" if is_custom_filter
when ">="
- sql = "#{db_table}.#{db_field} >= #{value.first.to_i}"
+ if is_custom_filter
+ sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) >= #{value.first.to_i}"
+ else
+ sql = "#{db_table}.#{db_field} >= #{value.first.to_i}"
+ end
when "<="
- sql = "#{db_table}.#{db_field} <= #{value.first.to_i}"
+ if is_custom_filter
+ sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) <= #{value.first.to_i}"
+ else
+ sql = "#{db_table}.#{db_field} <= #{value.first.to_i}"
+ end
when "o"
sql = "#{IssueStatus.table_name}.is_closed=#{connection.quoted_false}" if field == "status_id"
when "c"