2017-02-28 78 views
1

我有一系列複選框,用戶可以用它來找出由檢查屬性對象中的多個複製。我希望他們能夠選擇一些屬性,然後顯示包含所有這些檢查屬性對象的列表。的Rails ActiveRecord的查詢與對象的數組返回對象

我的代碼部分的工作,但如果我檢查一個屬性,我給出一個列表,然後我檢查另一屬性,已經從以前的檢查顯示,然後,我另一個副本。這是一個正在發生的事情的圖像。注意對象正在重複。

enter image description here

下面是與它去代碼:

<div class="col-md-2"> 
    <div class="dropdown package-dropdown"> 
     <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Attributes</button> 
     <ul class="dropdown-menu" aria-labelledby="dropdownMenuButton"> 
     <li><a href="#" class="small" data-value="attr1" tabIndex="-1"><input type="checkbox"/>attr1</a></li> 
     <li><a href="#" class="small" data-value="attr2" tabIndex="-1"><input type="checkbox"/>attr2</a></li> 
     <li><a href="#" class="small" data-value="attr3" tabIndex="-1"><input type="checkbox"/>attr3</a></li> 
     <li><a href="#" class="small" data-value="attr4" tabIndex="-1"><input type="checkbox"/>attr4</a></li> 
     <li><a href="#" class="small" data-value="attr5" tabIndex="-1"><input type="checkbox"/>attr5</a></li> 
     </ul> 
    </div> 
</div> 

<!-- removed irrelevant code for brevity --> 

    <tbody id="hits"> 
    <% @objects.each do |obj| %> 
     <tr> 
     <td><%= link_to obj.title, obj_path(obj) %></td> 
      <td class="package-column"> 
      <% if obj.packages.any? %> 
      <div> 
      <% obj.packages.each do |p| %> 
       <span><%= image_tag "needs-#{p.kind}", :alt => "#{p.kind}", :class => "foobar" %></span> 
      <% end %> 
      </div> 
      <% else %> 
      <div class="package-column"><span>...</span></div> 
     <% end %> 
     </td> 
     <td><%= obj.capacity %></td> 
     <td><%= obj.started_at.strftime('%A, %B %e, %Y at %l:%M %p') if obj.started_at? %></td> 
     </tr> 
    <% end %> 
    <tr><td colspan="4" align="center"><%= link_to "Load More", objects_path, class: "load-more" %></td></tr> 
    </tbody> 
</table> 

var options = []; 
$('.dropdown-menu li a').on('click', function(event) { 
var $target = $(event.currentTarget), 
    val = $target.attr('data-value'), 
    $inp = $target.find('input'), 
    idx; 

if ((idx = options.indexOf(val)) > -1) { 
    options.splice(idx, 1); 
    setTimeout(function() { $inp.prop('checked', false) }, 0); 
} else { 
    options.push(val); 
    setTimeout(function() { $inp.prop('checked', true) }, 0); 
} 

$(event.target).blur(); 

    console.log(options); 
    $.ajax({ 
    url: $(this).attr('href'), 
    type: "GET", 
    data: { 
     packages: options 
    }, 
    dataType: "script" 
    }) 
    return false; 
}); 

我的控制器在活動記錄查詢。

def index 
    if params[:packages] 
    packages = params[:packages] # ["attr1", "attr3" etc..] 
    @objects = Object.joins(:packages).where("packages.kind IN (?)", packages) 
    end 

    respond_to do |format| 
    format.html 
    format.js 
    end 
end 

我相信這是一個ActiveRecord的問題,而不是顯示器的問題,因爲如果我檢查@objects我顯示記錄的多個副本,像這樣:

[8] pry(#<ObjectsController>)> @objects 
=> [#<Object:0x007f991cb1d6b0 
    id: 2, 
    uuid: "1adede0e-8585-41a5-8c74-8de8eec6a141", 
    name: "andy-title1", 
    title: "Andy - Title1", 
    started_at: Mon, 27 Mar 2017 13:00:24 PDT -07:00, 
    ended_at: Mon, 27 Mar 2017 18:00:24 PDT -07:00 
#<Object:0x007f991cb1d548 
    id: 2, 
    uuid: "1adede0e-8585-41a5-8c74-8de8eec6a141", 
    name: "andy-title1", 
    title: "Andy - Title1", 
    started_at: Mon, 27 Mar 2017 13:00:24 PDT -07:00, 
    ended_at: Mon, 27 Mar 2017 18:00:24 PDT -07:00 
+1

注知道這是否會修復它,但問題可能與事實,你的模式被稱爲'Object'。我強烈建議您將其重命名爲更具描述性的數據。 'Object'是ruby中最基本的類之一,如果你使用它作爲模型,你可能會有一些微妙的命名空間衝突,並可能看到非常奇怪的行爲。我不認爲這與你當前的問題有關,但可能是,你應該改變它。 – Glyoko

+0

這樣做是爲了掩蓋我正在處理的數據。這不是真的叫'對象' – Antonio

+1

那麼,不要那麼着急。我真的想知道你是如何設法讓Object繼承ActiveRecord :: Base的! – Glyoko

回答

1

添加.distinct我查詢的末尾解決了我的問題,並會省略重複的記錄。

我現在的工作查詢:

@objects = Object.joins(:packages).where("packages.kind IN (?)", packages).distinct

+0

我認爲這是SQL連接的一個怪癖,它允許在某些情況下返回重複項。這裏使用不同的解決方案似乎是正確的 – Glyoko