Clase: Mongoid::Asociación::Referenciado::TieneMuchos
- Hereda:
-
Objeto
- Objeto
- Mongoid::Association::Referenced::HasMany
- Definido en:
- lib/mongoid/association/referenced/has_many.rb,
lib/mongoid/association/referenced/has_many/eager.rb,
lib/mongoid/association/referenced/has_many/proxy.rb,
lib/mongoid/association/referenced/has_many/binding.rb,
lib/mongoid/association/referenced/has_many/buildable.rb,
lib/mongoid/association/referenced/has_many/enumerable.rb
Overview
La asociación has_many.
Definido bajo Namespace
Modules: Construible Clases: Vínculo, Eager, Enumerable, Proxy
Colapso delresumen constante
- ASSOCIATION_OPTIONS =
Las opciones disponibles para este tipo de asociación, además de las comunes.
[ :después_de_agregar, Después de quitar, como, :autosave, antes_de_añadir, :before_remove, :dependiente, :foreign_key, :orden, :primary_key, :alcance, ].freeze
- VALID_OPTIONS =
La lista completa de opciones válidas para esta asociación, incluidas las compartidas.
(ASSOCIATION_OPTIONS + OPCIONES_COMPARTIDAS).freeze
- SUFIJO DE CLAVE EXTRANJERA =
El sufijo de clave externa predeterminado.
'_id'.freeze
Constantes incluidas de Mongoid::Association::Relatable
Mongoid::Association::Relatable::PRIMARY_KEY_DEFAULT, Mongoid::Association::Relatable::SHARED_OPTIONS
Resumen del atributo de la instancia
Atributos incluidos desde Mongoid::Association::Relatable
#nombre, #opciones, #inclusiones_superiores
Resumen del método de instancia colapsar
-
#add_polymorphic_criterion(criterios, clase_de_objeto) ⇒ Mongoid::Criteria
Obsoleto
Obsoleto.
en 9.0.x
-
#enlazable?(doc) ⇒ verdadero | falso
Si intentar vincular un objeto mediante esta asociación debería generar un error.
-
#criterios(base) ⇒ Mongoid::Criterios
Los criterios utilizados para consultar esta asociación.
-
#embedded? ⇒ false
¿Este tipo de asociación está embebido?
-
#foreign_key ⇒ String
Obtén el campo de clave foránea en la inversa para guardar la referencia de la asociación.
-
#nested_builder(attributes, options) ⇒ Association::Nested::Many
El objeto builder anidado.
-
#ruta(documento) ⇒ Raíz
Obtén la calculadora de rutas para el documento suministrado.
-
#polymorphic? ⇒ true | false
¿Es esta asociación polimórfica?.
-
#relación ⇒ Association::HasMany::Proxy
Obtenga la clase de proxy de asociación para este tipo de asociación.
-
#relation_complements ⇒ Array<Mongoid::Association::Relatable>
La lista de complementos de asociaciones.
-
#scope ⇒ Proc | Symbol | nil
Obtén el alcance que se aplicará al consultar la asociación.
-
#setup! ⇒ self
Configura los métodos, campos, etc. de la instancia.
-
#métodos_de_instancia_de_configuración! ⇒ self
Configurar los métodos de instancia en la clase que tenga este tipo de asociación.
-
#¿almacena_clave_externa? ⇒ verdadero
¿Este tipo de asociación almacena la clave foránea?.
-
#type ⇒ String | nil
El tipo de esta asociación si es polimórfica.
-
#validation_default ⇒ true
El valor por defecto para la validación del objeto de asociación.
Métodos incluidos en WithPolymorphicCriteria
Métodos incluidos en Buildable
Métodos incluidos de Mongoid::Association::Relatable
#==, #counter_cache_column_name, #create_relation, #destructive?, #extension, #foreign_key_check, #foreign_key_setter, #get_callbacks, #in_to?, #initialize, #inverse, #inverse_association, #inverse_class, #inverse_class_name, #inverse_setter, #inverse_type, #inverse_type_setter, #inverses, #key, #many?, #one?, #relation_class, #relation_class_name, #setter, #type_setter, #validate?
Métodos incluidos de Opciones
#as, #autobuilding?, #autosave, #cascading_callbacks?, #counter_cached?, #cyclic?, #dependent, #forced_nil_inverse?, #índice?, #inverse_of, #order, #primary_key, #store_as, #touch_field, #touchable?
Métodos incluidos de Constrainable
Detalles del método de instancia
#add_polymorphic_criterion(criteria, object_class) ⇒ Mongoid::Criteria
en 9.0.x
Añada criterios de query polimórficos a un objeto Criteria, si esta asociación es
polymorphic.
Parece que este método es un artefacto que quedó de una refactorización que lo renombró como ‘with_polymorphic_criterion`' y lo hizo privado. Sea como sea, este método no es referenciado en ningún otro lugar, y es poco probable que sea útil para clientes externos. Deberíamos removerlo.
142 143 144 145 146 147 148 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 142 def añadir criterio polimórfico(criterios, object_class) si polimórfico? criterios.dónde(tipo => object_class.Nombre) else criterios end end |
#enlazable?(doc) ⇒ verdadero | falso
Si intentar vincular un objeto mediante esta asociación debería generar un error.
164 165 166 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 164 def ¿vinculable?(doc) forced_nil_inverse? || (!!inversa && doc.campos.claves.incluir?(foreign_key)) end |
# criterios(base) ⇒ Mongoide::Criterios
Los criterios utilizados para consultar esta asociación.
116 117 118 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 116 def criterios(base) query_criteria(base.enviar(clave_primaria), base) end |
#¿integrado? ⇒ false
¿Este tipo de asociación está incrustado?
94
|
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 94 def ; false; end |
#foreign_key ⇒ String
Obtén el campo de clave foránea en la inversa para guardar la referencia de la asociación.
86 87 88 89 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 86 def foreign_key @clave_extranjera ||= @options[:foreign_key] ? @options[:foreign_key].to_s : default_foreign_key_field end |
#nested_builder(attributes, options) ⇒ Asociación::Anidada::Muchas
El objeto builder anidado.
174 175 176 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 174 def nested_builder(atributos, ) Anidado::Muchos.Nuevo(sí mismo, atributos, ) end |
#ruta(documento) ⇒ Raíz
Obtén la calculadora de rutas para el documento suministrado.
186 187 188 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 186 def ruta(Documento) Mongoid::Atómico::Rutas::Raíz.Nuevo(Documento) end |
#polimórfico? ⇒ true | false
¿Esta asociación es polimórfica?
154 155 156 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 154 def polimórfico? @polymorphic ||= !!como end |
#relación ⇒ Association::HasMany::Proxy
Obtenga la clase de proxy de asociación para este tipo de asociación.
109 110 111 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 109 def relación Apoderado end |
#complementos_de_relación ⇒ Matriz
La lista de complementos de asociaciones.
53 54 55 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 53 def relation_complements @relation_complements ||= [ Referenciado::BelongsTo ].freeze end |
#scope ⇒ Proc | Symbol | nil
Obtén el alcance que se aplicará al consultar la asociación.
193 194 195 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 193 def Alcance @options[:alcance] end |
#¡configuración! ⇒ yo mismo
Configura los métodos de instancia, campos, etc. en la clase propietaria de la asociación.
60 61 62 63 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 60 def setup! ¡métodos_de_instancia_de_configuración! sí mismo end |
#métodos_de_instancia_de_configuración! ⇒ self
Configurar los métodos de instancia en la clase que tenga este tipo de asociación.
68 69 70 71 72 73 74 75 76 77 78 79 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 68 def ¡métodos_de_instancia_de_configuración! define_getter! define_ids_getter! define_setter! define_ids_setter! definir_comprobación_de_existencia! define_autosaver! ¡polimórfico! define_dependency! @owner_class.valida_asociado(Nombre) si validate? sí mismo end |
#stores_foreign_key? ⇒ true
¿Este tipo de asociación almacena la clave externa?
104
|
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 104 def ¿stores_foreign_key?; false; end |
#type ⇒ String | nil
Solo aplicable a asociaciones polimórficas.
El tipo de esta asociación si es polimórfica.
125 126 127 |
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 125 def tipo @tipo ||= "#{as}_type" si polimórfico? end |
#validation_default ⇒ true
El valor por defecto para la validación del objeto de asociación.
99
|
# Archivo 'lib/mongoid/association/referenced/has_many.rb', línea 99 def validation_default; true; end |