모듈: Mongoid::Document
개요
이는 데이터베이스에 문서로 유지되어야 하는 모든 도메인 객체에 대한 기본 모듈입니다.
네임스페이스 아래에 정의됨
모듈: 클래스 메서드
상수 요약 접기
- ILLEGAL_KEY =
불법적인 BSON 키 일치에 대한 정규식. bson 4.1 에는 대신 사용해야 하는 상수 BSON::String::ILLEGAL_KEY가 있습니다. Ruby 드라이버 2.3.0 이 출시되고 Mongoid를 require >= 2.3.0 으로 업데이트할 수 있는 경우 BSON 상수를 사용할 수 있습니다.
/(\A[$])|(\.)/.동결
컴포저블에 포함된 상수
Composable::MODULES, Composable::RESERVED_METHOD_NAMES
Interceptable에서 포함된 상수
연관 관계에서 포함된 상수
연관 관계::에포함된 상수
Persistable에 포함된 상수
필드에서 포함된 상수
Fields::Boolean, Fields::IDS, Fields::INVALID_BSON_CLASSES, Fields::StringifiedSymbol , Fields::TYPE_MAPPINGS
Atomic에 포함된 상수
인스턴스 속성 요약 접기
-
#__selected_fields ⇒ 객체
__selected_fields 속성의 값을 반환합니다.
-
#new_record ⇒ 객체
읽기 전용
new_record 속성의 값을 반환합니다.
Stateful에 포함된 속성
#destoryed, #flaged_for_destory, #previously_new_record
연관 관계에서 포함된 속성
속성에 포함된 속성
Clients::StorageOptions에 포함된 속성
인스턴스 메서드 요약 접기
-
#_handle_callbacks_after_instantiation(execute_callbacks) ⇒ 객체
비공개
콜백을 실행해야 하는 경우 콜백의 설정 및 실행을 처리합니다. 그렇지 않으면 보류 중인 콜백 목록에 적절한 콜백을 추가합니다.
-
#as_document ⇒ 해시
이 문서 이하에서 전체 문서 계층 구조의 해시를 반환합니다.
-
#as_json(options = nil) ⇒ Hash
추가 Mongoid 관련 옵션을 사용하여 문서 에서 #as_json을 호출합니다.
-
#은(klass) ⇒ 문서가 됩니다.
현재 문서 의 속성, 오류 및 내장된 문서와 함께 지정된 클래스의 인스턴스 를 반환합니다.
-
#동결 ⇒ 문서
문서의 내부 속성을 동결합니다.
-
#frozen? ⇒ true | false
문서 가 동결되었는지 확인합니다.
-
#해시 ⇒ 정수
동일한 ID의 두 레코드가 다음과 같은 작업을 수행할 수 있도록 ID를 위임합니다.
-
#identity ⇒ 배열
문서는 클래스와 데이터베이스 ID로 절대적으로 식별됩니다.
-
#initialize(attrs = nil, &block) ⇒ Document
새
Document
을(를) 인스턴스화하고, 문서의 속성이 지정된 경우 설정합니다. -
#internal_state=(상태) ⇒ 객체
비공개
이 문서 의 내부 상태 를 설정합니다.
-
#모델 이름 ⇒ string
문서 의 모델 이름을 반환합니다.
-
#to_key ⇒ string
문서 의 키 값을 반환합니다.
Touchable::InstanceMethods에 포함된 메서드
#_clear_터치 _업데이트 , #_gather_터치_업데이트, #_런_터치_콜백스_프롬_루트 , #_터치 가능한 _부모?, #suppress_터치_콜백스, #터치, #터치_콜백스 _억제?
컴포저블에 포함된 메서드
Equality에 포함된 메서드
Copyable에 포함된 메서드
Interceptable에 포함된 메서드
#_mongoid_run_child_after_callbacks, #_mongoid_run_child_before_callbacks, #_mongoid_run_child_callbacks, #_mongoid_run_child_callbacks_with_round, #_mongoid_run_child_callbacks_without_round, #callback_executable, #in_callback_state?, #pending_callbacks, #pending_callbacks=, #run_after_callbacks, #run_before_callbacks, #run_callbacks, #run_pending_callbacks
Validatable에 포함된 메서드
#begin_validate, #exit_validate, #performing_validations?, #read_attribute_for_validation, #valid?, #validated?, #validating_with_query?
Traversable에 포함된 메서드
#_children, #_descendants, #_parent, #_parent=, #_reset_memoized_descendants!, #_root, #_root?, #collect_children, #collect_descendants, #flag_descendants_persisted, #hereditary?, #parentize, #remove_child, #reset_persisted_descendants
Cacheable에 포함된 메서드
Stateful에 포함된 메서드
#destoryed?, #flaged_for_destory?, #new_record=, #new_record?, #persisted?, #previously_new_record?, #previously_persisted?, #pushable?, #readonly!, #readonly?, #settable?, #updateable?
Shardable에 포함된 메서드
#shard_key_field_value, #shard_key_fields, #shard_key_selector, #shard_key_selector_in_db
Serializable에 포함된 메서드
Selectable에 포함된 메서드
Reloadable에 포함된 메서드
연관 관계에 포함된 메서드
#association_name, #embedded?, #embedded_many?, #embedded_one?, #referenced_many?, #referenced_one?, #reload_relations
연관 관계::리플렉션에 포함된 메서드
#reflect_on_all_association, #reflect_on_association
연관 관계::매크로에 포함된 메서드
연관 관계::에포함된 메서드
#apply_destory_dependencies!, 정의_종속성!, 유효성을 검사합니다!
연관 관계::접근자에 포함된 메서드
#__build__, #create_relation, #reset_relation_criteria, #set_relation
연관 관계::Referenced::Syncable에 포함된 메서드
#_syncable?, #_synced, #_synced?, #remove_inverse_keys, #update_inverse_keys
연관 관계::Referenced::CounterCache에 포함된 메서드
연관 관계::참조::자동 저장에 포함된 메서드
#__autosaving__, #autosaved?, #changed_for_autosave?, define_autosave!
Persistable에 포함된 메서드
#atomally, #fail_due_to_callback!, #fail_due_to_validation!
Persistable::Unsettable에 포함된 메서드
Persistable::Upsertable에 포함된 메서드
Persistable::Updatetable에 포함된 메서드
#update, #update!, #update_attribute
Persistable::Settable에 포함된 메서드
Persistable::Savable에 포함된 메서드
Persistable::Renameable에 포함된 메서드
Persistable::Pushable에 포함된 메서드
Persistable::Pullable에 포함된 메서드
Positional에 포함된 메서드
Persistable::Poppable에 포함된 메서드
Persistable::Multipliable에 포함된 메서드
Persistable::Minable에 포함된 메서드
Persistable::Maxable에 포함된 메서드
Persistable::Logical에 포함된 메서드
Persistable::Incrementable에 포함된 메서드
Persistable::Destoryable에 포함된 메서드
Persistable::Deletable에 포함된 메서드
Persistable::Creatable에 포함된 메서드
일치 항목에 포함된 메서드
필드에 포함된 메서드
#apply_default, #apply_defaults, #apply_post_processed_defaults, #apply_pre_processed_defaults, #attribute_names, database_field_name, #database_field_name, #dot_dollar_field?, #lazy_settable?, option, options, traverse_association_tree, #using_object_ids?, #validate_writeable_field_name!
E볼버블에 포함된 메서드
Attributes에 포함된 메서드
#assign_attributes, #attribute_missing?, #attribute_present?, #attributes_before_type_cast, #has_attribute?, #has_attribute_before_type_cast?, #process_raw_attribute, #read_attribute, #read_attribute_before_type_cast, #remove_attribute, #typed_attributes, #write_attribute, #write_attributes
Attributes::Readonly에 포함된 메서드
Attributes::Processing에 포함된 메서드
클라이언트에서 포함된 메서드
clear, 클라이언트, 기본값, 연결 해제, 설정하다, with_name
Clients::Sessions에 포함된 메서드
Client::Options에 포함된 메서드
# 컬렉션, #collection_name, #mongo_client, #persistence_context, #persistence_context?, #with
Clients::StorageOptions에 포함된 메서드
#remember_storage_options!, #storage_options
Changeable에 포함된 메서드
#attribute_before_last_save, #changed, #changed?, #changed_attributes, #changes , #children_changed ?, #move_changes, #post_persist, #previous_changes, #remove_change, #saved_change_to_attribute, #saved_change_to_attribute?, #setters, #write_save_change_to_attribute?
Atomic에 포함된 메서드
#add_atomic_pull, #add_atomic_unset, #atomic_array_add_to_sets, #atomic_array_pulls, #atomic_array_pushes, #atomic_attribute_name, #atomic_delete_modifier, #atomic_insert_modifier, #atomic_path, #atomic_paths, #atomic_position, #atomic_pulls, #atomic_pushes , #atomic_sets, #atomic_unsets , #atomic_updates, #delayed_atomic_pulls(예:
인스턴스 속성 세부 정보
#__selected_fields ⇒ 객체
__selected_fields 속성의 값을 반환합니다.
29 30 31 |
# 파일 'lib/mongoid/ 문서.rb', 29줄 def __selected_fields @__selected_fields end |
#new_record ⇒ 객체 (읽기 전용)
new_record 속성의 값을 반환합니다.
30 31 32 |
# 파일 'lib/mongoid/ 문서.rb', 30줄 def new_record @new_record end |
인스턴스 메서드 세부 정보
#_handle_callbacks_after_instantiation(execute_callbacks) ⇒ 객체
이 메서드는 비공개 API의 일부입니다. 이 방법은 향후 제거되거나 변경될 수 있으므로 가능하면 사용하지 않는 것이 좋습니다.
콜백을 실행해야 하는 경우 콜백의 설정 및 실행을 처리합니다. 그렇지 않으면 보류 중인 콜백 목록에 적절한 콜백을 추가합니다.
211 212 213 214 215 216 217 218 219 220 221 |
# 파일 'lib/mongoid/ 문서.rb', 211줄 def _handle_callbacks_after_instantiation(execution_callbacks) 만약 execution_callbacks apply_defaults yield self 만약 block_given? run_callbacks(:find) 하지 않는 한 _find_callbacks.비어 있나요? run_callbacks(:initialize) 하지 않는 한 _initialize_callbacks.비어 있나요? other yield self 만약 block_given? self.보류 중인_콜백 += %i[ apply_defaults 찾기 초기화 ] end end |
#as_document ⇒ 해시
이 문서 이하에서 전체 문서 계층 구조의 해시를 반환합니다. 현재 문서뿐만 아니라 모든 것에 속성이 필요할 때 사용됩니다.
134 135 136 |
# 파일 'lib/mongoid/ 문서.rb', 134줄 def as_document BSON::문서.신규(as_attributes) end |
#as_json(options = nil) ⇒ Hash
Rails 6 는 BSON::ObjectId와 같은 기본이 아닌 유형에 대해 as_json의 반환 값을 변경합니다. Rails <= 5 에서 as_json은 이를 클래스의 인스턴스로 반환했습니다. Rails 6 에서는 기본 유형으로 직렬화되어 반환됩니다(예: '$oid'=>' 5bcfc40bde340b37feda98e9'). github.com/rails/rails/ 커밋/2e5cb980a448e7f4ab00df6e df941456616 참조 c cc aa 을(를) 참조하세요.
추가 Mongoid 관련 옵션을 사용하여 문서 에서 #as_json을 호출합니다.
156 157 158 159 160 161 162 163 |
# 파일 'lib/mongoid/ 문서.rb', 156줄 def as_json( = nil) rv = super 만약 && [:compact] 몽고이드::경고.warn_as_json_compact_deprecated rv = rv.컴팩트 end rv end |
#은(klass) ⇒ 문서가 됩니다.
현재 문서 의 속성, 오류 및 내장된 문서와 함께 지정된 클래스의 인스턴스 를 반환합니다.
176 177 178 179 180 181 182 183 |
# 파일 'lib/mongoid/ 문서.rb', 176줄 def 됩니다.(class) mongoid_document_check!(class) 되었다 = class.신규(clone_document) 되었다.internal_state = internal_state 되었다 end |
#freeze ⇒ Document
문서의 내부 속성을 동결합니다.
49 50 51 |
# 파일 'lib/mongoid/ 문서.rb', 49줄 def 동결 as_attributes.동결 개인정보 정책에 self end |
#frozen? ⇒ true | false
문서 가 동결되었는지 확인합니다.
59 60 61 |
# 파일 'lib/mongoid/ 문서.rb', 59줄 def 동결? 속성.동결? end |
#해시 ⇒ 정수
동일한 ID의 두 레코드가 다음과 같이 작업할 수 있도록 ID를 위임합니다.
[ Person.find(1), Person.find(2), Person.find(3) ] &
[ Person.find(1), Person.find(4) ] # => [ Person.find(1) ]
73 74 75 |
# 파일 'lib/mongoid/ 문서.rb', 73줄 def 해시 신원.해시 end |
#identity ⇒ 배열
문서는 클래스와 데이터베이스 ID로 절대적으로 식별됩니다.
Person.first.identity #=> [Person, BSON::ObjectId(' 4f775130a04745933a000003')]
85 86 87 |
# 파일 'lib/mongoid/ 문서.rb', 85줄 def 신원 [ self.클래스, _id ] end |
#initialize(attrs = nil, &block) ⇒ 문서
새 Document
을(를) 인스턴스화하고, 문서의 속성이 지정된 경우 설정합니다. 속성이 제공되지 않으면 빈 Hash
으)로 초기화됩니다.
기본 키가 정의된 경우 문서의 ID 는 해당 키로 설정되고, 그렇지 않으면 새로운 BSON::ObjectId
string 로 설정됩니다.
102 103 104 |
# 파일 'lib/mongoid/ 문서.rb', 102줄 def 초기화(attrs = nil, &차단) configure_document(attrs, &차단) end |
#internal_state=(상태) ⇒ 객체
이 메서드는 비공개 API의 일부입니다. 이 방법은 향후 제거되거나 변경될 수 있으므로 가능하면 사용하지 않는 것이 좋습니다.
이 문서 의 내부 상태 를 설정합니다. 재입력 문서 를 초기화하는 데 도움이 되는 #becomes 에서만 사용됩니다.
191 192 193 194 195 196 197 198 199 200 201 |
# 파일 'lib/mongoid/ 문서.rb', 191줄 def internal_state=(상태) self._id = 상태[:id] @changed_attributes = 상태[:changed_attributes] @errors = ActiveModel::오류.신규(self).탭 { |e| e.복사!(상태[:errors]) } @new_record = 상태[:new_record] @destoryed = 상태[:destoryed] update_discrirator(상태[:discrirator_key_was]) (상태[:new_record]) end |
#모델 이름 ⇒ string
문서 의 모델 이름을 반환합니다.
112 113 114 |
# 파일 'lib/mongoid/ 문서.rb', 112줄 def 모델 이름 self.클래스.모델 이름 end |
#to_key ⇒ string
문서 의 키 값을 반환합니다.
122 123 124 |
# 파일 'lib/mongoid/ 문서.rb', 122줄 def to_key (지속되었나요? || 파괴?) ? [ _id.to_s ] : nil end |