summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2007-08-26 12:29:53 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2007-08-26 12:29:53 +0000
commit8da5bad29516be6cbe1bc52e78837ac1ec292026 (patch)
treeec32a3548a51d0f3f1e33920e17bc54e2b40460c /app
parent452a20a69a574346f9ae8876e5402aabb11edbd5 (diff)
downloadredmine-8da5bad29516be6cbe1bc52e78837ac1ec292026.tar.gz
redmine-8da5bad29516be6cbe1bc52e78837ac1ec292026.zip
Fixed: queries with multiple custom fields return no result.
git-svn-id: http://redmine.rubyforge.org/svn/trunk@668 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/controllers/feeds_controller.rb4
-rw-r--r--app/controllers/projects_controller.rb6
-rw-r--r--app/models/query.rb29
3 files changed, 22 insertions, 17 deletions
diff --git a/app/controllers/feeds_controller.rb b/app/controllers/feeds_controller.rb
index aaba4ac57..0601b8a5e 100644
--- a/app/controllers/feeds_controller.rb
+++ b/app/controllers/feeds_controller.rb
@@ -45,7 +45,7 @@ class FeedsController < ApplicationController
end
Issue.with_scope(:find => @find_options) do
- @issues = Issue.find :all, :include => [:project, :author, :tracker, :status, :custom_values],
+ @issues = Issue.find :all, :include => [:project, :author, :tracker, :status],
:order => "#{Issue.table_name}.created_on DESC"
end
@title = (@project ? @project.name : Setting.app_title) + ": " + (query ? query.name : l(:label_reported_issues))
@@ -65,7 +65,7 @@ class FeedsController < ApplicationController
end
Journal.with_scope(:find => @find_options) do
- @journals = Journal.find :all, :include => [ :details, :user, {:issue => [:project, :author, :tracker, :status, :custom_values]} ],
+ @journals = Journal.find :all, :include => [ :details, :user, {:issue => [:project, :author, :tracker, :status]} ],
:order => "#{Journal.table_name}.created_on DESC"
end
diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb
index 86248e498..0613f9e40 100644
--- a/app/controllers/projects_controller.rb
+++ b/app/controllers/projects_controller.rb
@@ -290,10 +290,10 @@ class ProjectsController < ApplicationController
end
if @query.valid?
- @issue_count = Issue.count(:include => [:status, :project, :custom_values], :conditions => @query.statement)
+ @issue_count = Issue.count(:include => [:status, :project], :conditions => @query.statement)
@issue_pages = Paginator.new self, @issue_count, @results_per_page, params['page']
@issues = Issue.find :all, :order => sort_clause,
- :include => [ :assigned_to, :status, :tracker, :project, :priority, :custom_values ],
+ :include => [ :assigned_to, :status, :tracker, :project, :priority ],
:conditions => @query.statement,
:limit => @issue_pages.items_per_page,
:offset => @issue_pages.current.offset
@@ -369,7 +369,7 @@ class ProjectsController < ApplicationController
render :action => 'list_issues' and return unless @query.valid?
@issues = Issue.find :all, :order => sort_clause,
- :include => [ :author, :status, :tracker, :priority, :project, :custom_values ],
+ :include => [ :author, :status, :tracker, :priority, :project ],
:conditions => @query.statement,
:limit => Setting.issues_export_limit.to_i
diff --git a/app/models/query.rb b/app/models/query.rb
index 88946655f..28f65ddf6 100644
--- a/app/models/query.rb
+++ b/app/models/query.rb
@@ -164,7 +164,8 @@ class Query < ActiveRecord::Base
end
def statement
- sql = "1=1"
+ # project/subprojects clause
+ clause = ''
if has_filter?("subproject_id")
subproject_ids = []
if operator_for("subproject_id") == "="
@@ -172,27 +173,29 @@ class Query < ActiveRecord::Base
else
subproject_ids = project.active_children.collect{|p| p.id}
end
- sql << " AND #{Issue.table_name}.project_id IN (%d,%s)" % [project.id, subproject_ids.join(",")] if project
+ clause << "#{Issue.table_name}.project_id IN (%d,%s)" % [project.id, subproject_ids.join(",")] if project
else
- sql << " AND #{Issue.table_name}.project_id=%d" % project.id if project
+ clause << "#{Issue.table_name}.project_id=%d" % project.id if project
end
+
+ # filters clauses
+ filters_clauses = []
filters.each_key do |field|
next if field == "subproject_id"
v = values_for(field).clone
next unless v and !v.empty?
-
- sql = sql + " AND " unless sql.empty?
- sql << "("
-
+
+ sql = ''
if field =~ /^cf_(\d+)$/
# custom field
db_table = CustomValue.table_name
- db_field = "value"
- sql << "#{db_table}.custom_field_id = #{$1} AND "
+ db_field = 'value'
+ sql << "#{Issue.table_name}.id IN (SELECT #{db_table}.customized_id FROM #{db_table} where #{db_table}.customized_type='Issue' AND #{db_table}.customized_id=#{Issue.table_name}.id AND #{db_table}.custom_field_id=#{$1} AND "
else
# regular field
db_table = Issue.table_name
db_field = field
+ sql << '('
end
# "me" value subsitution
@@ -232,9 +235,11 @@ class Query < ActiveRecord::Base
when "!~"
sql = sql + "#{db_table}.#{db_field} NOT LIKE '%#{connection.quote_string(v.first)}%'"
end
- sql << ")"
-
+ sql << ')'
+ filters_clauses << sql
end if filters and valid?
- sql
+
+ clause << (' AND ' + filters_clauses.join(' AND ')) unless filters_clauses.empty?
+ clause
end
end