Clase: Mongoid::Asociación::Referenciado::TieneYPerteneceAMuchos
- Hereda:
-
Objeto
- Objeto
- Mongoid::Asociación::Referenciado::TieneYPerteneceAMuchos
- Incluye:
- Construible, Mongoid::Asociación::Relacionable
- Definido en:
- lib/mongoid/asociación/referenciado/tiene_y_pertenece_a_muchos.rb,
lib/mongoid/asociación/referenciado/tiene_y_pertenece_a_muchos/eager.rb,
lib/mongoid/asociación/referenciado/tiene_y_pertenece_a_muchos/proxy.rb,
lib/mongoid/asociación/referenciado/tiene_y_pertenece_a_muchos/binding.rb,
lib/mongoid/asociación/referenciado/tiene_y_pertenece_a_muchos/buildable.rb
Overview
La asociación de tipo HasAndBelongsToMany.
Definido en el espacio de nombres
Modules: Construible Clases: Vinculante, ansioso, proxy
Colapso delresumen constante
- OPCIONES DE ASOCIACIÓN =
Las opciones disponibles para este tipo de asociación, además de las comunes.
[ :después de agregar, :después de eliminar, :autosave, :antes_de_agregar, :antes_de_eliminar, :counter_cache, :dependiente, :clave externa, :index, :orden, :clave_principal, :clave primaria inversa, :clave externa inversa, :alcance, ].freeze
- VALID_OPTIONS =
La lista completa de opciones válidas para esta asociación, incluidas las compartidas.
(OPCIONES DE ASOCIACIÓN + OPCIONES_COMPARTIDAS).freeze
- TIPO DE CAMPO DE CLAVE EXTERNA =
El tipo de campo que contiene la clave externa.
Arreglo- SUFIJO DE CLAVE EXTRANJERA =
El sufijo de clave externa predeterminado.
'_ids'.freeze
Constantes incluidas de Mongoid::Association::Relatable
Mongoid::Asociación::Relacionable::CLAVE_PRIMARIA_POR_DETECCIÓN, Mongoid::Asociación::Relacionable::OPCIONES_COMPARTIDAS
Resumen de atributos de instancia
Atributos incluidos de Mongoid::Association::Relatable
#nombre, #opciones, #inclusiones_principales
Colapso del resumen del método de instancia
-
#enlazable?(doc) ⇒ verdadero | falso
Si intentar vincular un objeto mediante esta asociación debería generar un error.
-
#criteria(base, id_list = nil) ⇒ Mongoid::Criteria
Los criterios utilizados para consultar esta asociación.
-
#¿incrustado? ⇒ falso
¿Este tipo de asociación está integrado?
-
# ¿inversonulo forzado? ⇒ verdadero | falso
¿Los identificadores solo se guardan en este lado de la asociación?
-
#clave_externa ⇒ Cadena
Obtenga el campo de clave externa para guardar la referencia de asociación.
-
#clave_foránea_inversa ⇒ Cadena
Obtenga el campo de clave externa en la inversa.
-
#inverse_foreign_key_setter ⇒ String
Obtenga el establecedor de clave externa en la inversa.
-
#nested_builder(atributos, opciones) ⇒ Asociación::Anidado::Uno
El objeto constructor anidado.
-
#ruta(documento) ⇒ Raíz
Obtenga la calculadora de ruta para el documento proporcionado.
-
#relación ⇒ Asociación::TieneYPerteneceAMuchos::Proxy
Obtenga la clase de proxy de asociación para este tipo de asociación.
-
#complementos_de_relación ⇒ Matriz<Mongoid::Asociación::Relacionable><Mongoid::Association::Relatable>
La lista de complementos de la asociación.
-
#scope ⇒ Proc | Symbol | nil
Obtenga el alcance que se aplicará al consultar la asociación.
-
#¡configuración! ⇒ yo mismo
Configurar los métodos de instancia, campos, etc.
-
#¿almacena_clave_externa? ⇒ verdadero
¿Este tipo de asociación almacena la clave externa?
-
#validation_default ⇒ false
El valor predeterminado para la validación del objeto de asociación.
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 en Opciones
#como, #autoconstrucción?, #autoguardado, #devoluciones_de_llamadas_en_cascada?, #contador_en_caché?, #cíclico?, #dependiente, #indexado?, #inverso_de, #orden, #polimórfico?, #clave_principal, #almacenar_como, #campo_táctil, #tocable?, #tipo
Métodos incluidos de Constrangible
Detalles del método de instancia
#enlazable?(doc) ⇒ verdadero | falso
Si intentar vincular un objeto mediante esta asociación debería generar un error.
136 137 138 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 136 def ¿vinculable?(doc) forced_nil_inverse? || (!!inverso && doc.campos.claves.¿incluir?(clave externa)) end |
#criteria(base, id_list = nil) ⇒ Mongoid::Criteria
Los criterios utilizados para consultar esta asociación.
110 111 112 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 110 def criterios(base, lista de id = nulo) query_criteria(lista de id || base.Enviar(clave externa)) end |
#¿incrustado? ⇒ falso
¿Este tipo de asociación está integrado?
73 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 73 def ; false; end |
# ¿inversonulo forzado? ⇒ verdadero | falso
¿Los identificadores solo se guardan en este lado de la asociación?
83 84 85 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 83 def forced_nil_inverse? @forced_nil_inverse ||= @opciones.key?(:inverso_de) && !@opciones[:inverso_de] end |
#foreign_key ⇒ String
Obtenga el campo de clave externa para guardar la referencia de asociación.
102 103 104 105 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 102 def clave externa @clave_extranjera ||= @opciones[:clave externa] ? @opciones[:clave externa].a_s : campo de clave externa predeterminado end |
#inverse_foreign_key ⇒ String
Obtenga el campo de clave externa en la inversa.
118 119 120 121 122 123 124 125 126 127 128 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 118 def clave externa inversa Si @opciones.key?(:clave externa inversa) @opciones[:clave externa inversa] elsif @opciones.key?(:inverso_de) inverso_de ? "#{inverso_de.a_s.singularizar}#{SUFIJO_DE_CLAVE_EXTRANJERA}" : nulo elsif inversión = asociación inversa&.clave externa inversión else "#{ nombre_clase_inversa.demodulize. guión_bajo}#{SUFIJO_CLAVE_EXTRAÑA}" end end |
#inverse_foreign_key_setter ⇒ String
Obtenga el establecedor de clave externa en la inversa.
144 145 146 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 144 def definidor de clave externa inversa @configurador de claves foráneas inversas ||= "#{clave_extranjera_inversa}=" Si clave externa inversa end |
#nested_builder(atributos, opciones) ⇒ Asociación::Anidado::Uno
El objeto constructor anidado.
154 155 156 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 154 def constructor anidado(atributos, ) Anidado::Muchos.Nuevo(yo, atributos, ) end |
#ruta(documento) ⇒ Raíz
Obtenga la calculadora de ruta para el documento proporcionado.
166 167 168 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 166 def ruta(Documento) Mongoid::Atómico::Caminos::Raíz.Nuevo(Documento) end |
#relación ⇒ Asociación::TieneYPerteneceAMuchos::Proxy
Obtenga la clase de proxy de asociación para este tipo de asociación.
95 96 97 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 95 def relación Apoderado end |
#complementos_de_relación ⇒ Matriz
La lista de complementos de la asociación.
58 59 60 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 58 def relación_complementos @relation_complements ||= [ yo.clase ].freeze end |
#scope ⇒ Proc | Symbol | nil
Obtenga el alcance que se aplicará al consultar la asociación.
173 174 175 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 173 def ámbito de aplicación @opciones[:alcance] end |
#¡configuración! ⇒ yo mismo
Configure los métodos de instancia, campos, etc. en la clase propietaria de la asociación.
65 66 67 68 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 65 def setup! ¡métodos_de_instancia_de_configuración! yo end |
#¿almacena_clave_externa? ⇒ verdadero
¿Este tipo de asociación almacena la clave externa?
90 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 90 def ¿almacena_clave_extranjera?; true; end |
#validation_default ⇒ false
El valor predeterminado para la validación del objeto de asociación.
78 |
# Archivo 'lib/mongoid/association/referenced/has_and_belongs_to_many.rb', línea 78 def validation_default; true; end |