Монгоидный upsert с другим ключом

Можно ли перейти в коллекцию mongodb с JSON/хэшем полей, но вместо использования поля _id ObjectId использовать другое индексированное поле, например external_id?

Я использую его для обновления некоторых элементов, которые я ежедневно получаю из фида, и поэтому элементы фида не содержат моего внутреннего идентификатора.


person Avishai    schedule 01.07.2012    source источник


Ответы (1)


Да, в Mongoid можно добавить собственный идентификатор, но только в 3.0.0.rc примерно 27 июня 2012 г.

приложение/модели/item.rb

class Item
  include Mongoid::Document

  field :external_id, type: String
  field :_id, type: String, default: ->{ external_id }
  field :text, type: String
end

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

require 'test_helper'

class ItemTest < ActiveSupport::TestCase
  def setup
    Item.delete_all
  end

  test "external id" do
    Item.new( text: 'Lorem ipsum' ).upsert
    Item.new( external_id: 'an external id', text: 'dolor sit amet' ).upsert
    puts Item.all.to_a.collect{|item|item.inspect}
  end
end

выход

Параметры запуска: --name=test_external_id

# Running tests:

#<Item _id: 4ff202501f98ce8202c03268, _type: nil, external_id: nil, text: "Lorem ipsum">
#<Item _id: an external id, _type: nil, external_id: "an external id", text: "dolor sit amet">
.

Finished tests in 0.028232s, 35.4208 tests/s, 0.0000 assertions/s.

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

Для этого вам нужно будет установить с github, посетить и клонировать с

https://github.com/mongoid/mongoid

bundle install
bundle exec rake install

Вот ссылка на коммит, который делает это возможным.

https://github.com/mongoid/mongoid/commit/3062363bad3ab947d7689502d6805652b20e89a0
person Gary Murakami    schedule 02.07.2012