Mongoid order_by логический - PullRequest
       21

Mongoid order_by логический

2 голосов
/ 28 ноября 2011

В моей базе данных есть таблица уведомлений, которая содержит атрибуты: timestamp:datetime и read:boolean. Я хочу запросить и заказать мои уведомления; сначала, если они прочитаны или нет, затем, после какой полученной метки времени, ограничьте количество уведомлений до 10.

Запрос, который я пробовал, выглядит примерно так:

@user.notifications.order_by([[:read,:desc],[:timestamp,:desc]]).limit(10)

Который только дает мне ошибку, которую я сузил до доказательства булева поля как виновника.

Существует ли существующий способ упорядочения по значениям true / false или мне следует прибегнуть к использованию какой-либо сериализации настраиваемого поля, преобразующей значения True и False в 1 и 0?

1 Ответ

3 голосов
/ 29 мая 2012

То, что вы укажете, работает для меня с Mongoid 2.4.10, mongo 1.3, rails 3.2.3. Надеюсь, что следующее поможет решить вашу проблему.

class User
  include Mongoid::Document

  field :name, type: String
  has_many :notifications
end

class Notification
  include Mongoid::Document

  field :read, type: Boolean
  field :timestamp, type: DateTime
  belongs_to :user
end

тест / блок / notification_test.rb

require 'test_helper'

class NotificationTest < ActiveSupport::TestCase
  def setup
    User.delete_all
    Notification.delete_all
  end

  test "order_by boolean" do
    @user = User.create(name: 'Gary')
    [
      [true, 1.day.ago], [false, 2.days.ago], [false, 3.days.ago], [true, 5.days.ago], [false, 8.days.ago], [true, 11.days.ago],
      [false, 4.days.ago], [true, 6.days.ago], [true, 7.days.ago], [false, 9.days.ago], [false, 10.days.ago]
    ].each do |read, timestamp|
      @user.notifications << Notification.create(read: read, timestamp: timestamp)
    end
    assert_equal(1, User.count)
    assert_equal(11, Notification.count)
    result = @user.notifications.order_by([[:read,:desc],[:timestamp,:desc]]).limit(10).to_a
    assert_equal(10, result.size)
    result.each do |r|
      p [r.read, r.timestamp]
    end
  end
end

тестовый вывод

Run options: --name=test_order_by_boolean

# Running tests:

[true, Mon, 28 May 2012 12:33:49 -0400]
[true, Thu, 24 May 2012 12:33:49 -0400]
[true, Wed, 23 May 2012 12:33:49 -0400]
[true, Tue, 22 May 2012 12:33:49 -0400]
[true, Fri, 18 May 2012 12:33:49 -0400]
[false, Sun, 27 May 2012 12:33:49 -0400]
[false, Sat, 26 May 2012 12:33:49 -0400]
[false, Fri, 25 May 2012 12:33:49 -0400]
[false, Mon, 21 May 2012 12:33:49 -0400]
[false, Sun, 20 May 2012 12:33:49 -0400]
.

Finished tests in 0.023062s, 43.3614 tests/s, 130.0841 assertions/s.

1 tests, 3 assertions, 0 failures, 0 errors, 0 skips
...