diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2011-07-10 18:09:40 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2011-07-10 18:09:40 +0000 |
commit | bf15b06d98a8db28d610e38f8266d03d018a3b9f (patch) | |
tree | 3d565031e6c12a4ce2939d6556914c77aa7b8945 /app/models/query.rb | |
parent | 4507aa5014184081f2bdce175bac7a9c20fcd8b4 (diff) | |
download | redmine-bf15b06d98a8db28d610e38f8266d03d018a3b9f.tar.gz redmine-bf15b06d98a8db28d610e38f8266d03d018a3b9f.zip |
Fixes filters on float values.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@6227 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/query.rb')
-rw-r--r-- | app/models/query.rb | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/app/models/query.rb b/app/models/query.rb index 7746af88e..33fe2ec5f 100644 --- a/app/models/query.rb +++ b/app/models/query.rb @@ -123,6 +123,7 @@ class Query < ActiveRecord::Base :date_past => [ "=", ">=", "<=", "><", ">t-", "<t-", "t-", "t", "w" ], :string => [ "=", "~", "!", "!~" ], :text => [ "~", "!~" ], + # TODO: should be :numeric :integer => [ "=", ">=", "<=", "><", "!*", "*" ] } cattr_reader :operators_by_filter_type @@ -633,9 +634,9 @@ class Query < ActiveRecord::Base sql = date_clause(db_table, db_field, (Date.parse(value.first) rescue nil), nil) else if is_custom_filter - sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) >= #{value.first.to_i}" + sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) >= #{value.first.to_f}" else - sql = "#{db_table}.#{db_field} >= #{value.first.to_i}" + sql = "#{db_table}.#{db_field} >= #{value.first.to_f}" end end when "<=" @@ -643,9 +644,9 @@ class Query < ActiveRecord::Base sql = date_clause(db_table, db_field, nil, (Date.parse(value.first) rescue nil)) else if is_custom_filter - sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) <= #{value.first.to_i}" + sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) <= #{value.first.to_f}" else - sql = "#{db_table}.#{db_field} <= #{value.first.to_i}" + sql = "#{db_table}.#{db_field} <= #{value.first.to_f}" end end when "><" @@ -653,9 +654,9 @@ class Query < ActiveRecord::Base sql = date_clause(db_table, db_field, (Date.parse(value[0]) rescue nil), (Date.parse(value[1]) rescue nil)) else if is_custom_filter - sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) BETWEEN #{value[0].to_i} AND #{value[1].to_i}" + sql = "CAST(#{db_table}.#{db_field} AS decimal(60,3)) BETWEEN #{value[0].to_f} AND #{value[1].to_f}" else - sql = "#{db_table}.#{db_field} BETWEEN #{value[0].to_i} AND #{value[1].to_i}" + sql = "#{db_table}.#{db_field} BETWEEN #{value[0].to_f} AND #{value[1].to_f}" end end when "o" |