Table of Contents
Durante los últimos días de selección, algunos usuarios nos informaron que obtuvieron todos los errores de activación 1235 de mysql.
Aprobado
g.Este error significa que antes tiene un disparador AFTER INSERT para adaptarse a la tabla de colección. DROP TRIGGER vipInvite; DELIMITER $$ CREAR ACTIVADOR vipInvite END $$ DELIMITER; Ahora, si sufre de un objetivo diferente, necesita combinar el código de los disparadores del paso 2 en uno, luego eliminar el disparador principal existente y luego crear uno nuevo grande.
gramo.
electrónico
El otro día me quedé atascado durante varios hasta que ocurrió este problema. He estado usando activadores en SQL durante un período sin requisitos de servidor, pero una nueva implementación de MySQL a menudo es cuestionable.
Ayer, al intentar restaurar toda la base de datos, generé el error 1235:
ERROR 1235 (42000) en la línea telefónica 1408: Esta opción de MySQL aún no solo resuelve “múltiples disparadores con la acción correspondiente, suficiente tiempo y eventos relacionados con la tabla”
Busqué en Google durante aproximadamente una hora y llegué a la conclusión de que el tipo de error en el resultado final puede aparecer potencialmente si hay varias razones beneficiosas. También explico estas razones sobre las soluciones a continuación.
Creado solo por todos en primer lugar, le sugiero que obtenga una nueva cantidad de todos los activadores ejecutando todos los siguientes comandos:
SELECT trigger_schema, trigger_nameFROM information_schema.triggersDONDE trigger_schema = 'NAME_OF_YOUR_DATABASE';
Razón n. ° 1: no puede combinar ANTES / DESPUÉS con INSERTAR / ACTUALIZAR / ELIMINAR
Este archivo PDF describe el problema. El problema se puede describir como simplificado: BEFORE_INSERT no puede tener AFTER_INSERT a través de la misma tabla. Puede mantener actualizado el pedido ANTES de insertarlo todo y posteriormente actualizar otros tipos creados por insertar tablas con ID. Te revelo que mueves algo de acuerdo con el tipo de lógica (tal vez ANTES de decir todos los disparadores) en tu código.
Razón n. ° 2: AFTER_DELETE a veces por error 1235
Los activadores AFTER_DELETE deben usarse mucho. Cambiar al objetivo BEFORE_DELETE tiene sentido cuando la mayoría de las personas asisten a la variable OLD. No tengo ni idea de por qué sucederá esto, el programa podría ser mi producción específica de MySQL.
Razón 3: no puede venir con los mismos cargos (activadores dobles)
A veces, por ejemplo, en el proceso, una persona obtiene un código de error diferente, aunque a veces una persona obtiene el mismo error 1235 específico sin dar ningún problema. Revise la llamada telefónica de los desencadenantes del programa anterior y busque los desencadenantes con el mismo nombre. Ejecute siempre TRIGGER antes de crear / modificar un efecto.
Razón # 4: tiene dificultades para hacer referencia a UNA TABLA que normalmente actualiza / inserta en un mensaje
Por ejemplo, si le gustaría establecer su propia contraseña fácil de usar por defecto basada en un activador cada vez que esté creando entradas de usuario adicionales, podría intentar lo siguiente: ACTUALIZAR usuarios ESTABLECER contraseña = “newPassword” ;
La forma adecuada de hacer esto es establecer una variable en el disparador BEFORE_INSERT. Ejemplo: INSTALAR NUEVO. = Contraseña “newPassword”;
Razón n. ° 5: al exportar una base de datos (como un script SQL), puede obtener actualizaciones del sitio web en un script
En muchas otras palabras, si exporta la base de datos MySQL por ruta a un .File, el archivo manual real puede darle cosas como TRIGGER “mydbname” probablemente “trigger_name”. Entonces, si intenta traerlo de vuelta a la base de datos con un nombre diferente, se equivocará. Esperaba diferentes fallas en el sistema porque la base de datos NO se dirige a la base de datos que seguramente quiero restaurar. De todos modos, es posible que también obtenga el error 1235 aquí.
Solución corta: abra la carpeta .sql y cambie todas las referencias a EXPORTED_DB_NAME. ignorar la cadena (es decir, reemplazar, no desarrollar nada).
Reanudar / TL; DR:
No usar ANTES / ACTUALIZAR puede resultar en la misma función (como INSERTAR) en la misma tabla. Nunca use activadores AFTER_DELETE, en su lugar opere before_delete. Evite crear apodos duplicados. No haga referencia a la misma tabla de personas que está actualizando o posiblemente insertando donde está usando mi disparador, VIEJO además de NUEVO, sino use SET en una subconsulta en particular. Al restaurar una base de datos entre una copia de seguridad, el nombre de usuario explícito relacionado con la base de datos se menciona en estos pagos, que no incluye nuestra propia copia de seguridad (en caso de restauración, que puede tener un nombre de almacenamiento diferente).
Recuerde: con el disparador create INSERT su negocio solo puede usar un NUEVO número, con el disparador create UPDATE el individuo puede usar OLD con NEW, y además en la declaración DELETE también puede referirse a oney ‘en OLD.
- Etiquetas:
- 1235
- después
- after_delete
- antes
- consolidar
- base de datos
- denotar
- error
- base de datos mysql
- enlace
- revivir
- mismo asiento
- soluciones
,
,
,
,
,
,
,
,
,
,
,
,
En otro día, me encontré con estos problemas durante horas. He estado usando SQL durante muchos años. Sin un servidor, esto es un problema, pero la implementación en MySQL es sin duda muy cuestionable.
El problema que encontré recientemente al restaurar algún tipo de colección es el error 1235:
ERROR 1235 (42000) en la línea 1408 uno: esta versión de MySQL no admite aún “múltiples activadores debido a que te ayudarán con la misma duración y una clase para una tabla”
Lo encontré en Google aproximadamente una hora por hora y llegué a la conclusión de que, a su vez, este error puede ocurrir por varias razones. Explico estas razones y, en consecuencia, las pongo a disposición en las herramientas a continuación.
En primer lugar, le sugiero que obtenga una lista de todos los activadores ejecutando los comandos adecuados:
SELECT nombre-disparadorFROM trigger_schema, information_schema.triggersWO trigger_schema coincide con PDF "your_database_name";
esto en particular describe este problema. El problema es simple: no puede recomendar BEFORE_INSERT y AFTER_INSERT para la misma tabla exacta. Es posible que hayas actualizado cómo la columna ANTES de insertarla y es entonces cuando se actualiza la inserción de otra lista con ID. Le sugiero que lleve algo de esta lógica (posiblemente ANTES de que se dispare el gatillo) en su computadora. Sigue
No está aprovechando los activadores AFTER_DELETE. La lógica para salir corriendo al disparador BEFORE_DELETE si y / o cuando usa un OLD ajustable. No tengo idea de por qué están sucediendo nuevamente, puede ser más mi propia versión de MySQL.
Razón n. ° 3: actualmente no puede tener desencadenantes con la misma competencia (desencadenantes duplicados)
A veces, trae una regla de error diferente, pero con frecuencia obtiene un error 1235 idéntico gracias a la falta de explicación. Ejecute una consulta moderna para ver los desencadenantes documentados anteriormente y encontrar los desencadenantes, todos los principales con el mismo concepto. Ejecute siempre TRIGGER antes de crear y modificar un disparador.
Razón número 4: no puede hacer referencia a los propietarios de la MISMA TABLA que ellos actualizan o insertan en cada activador
Por ejemplo, si desea recopilar una contraseña predeterminada para psturgeon acompañada de un activador al crear un registro de usuario fantástico diferente, puede hacer: ACTUALIZAR usuarios de pc SET = cambiar “newPassword”;
La forma correcta de hacer esto es poner una variable particular en el producto BEFORE_INSERT. Ejemplo: ESTABLECER NUEVA contraseña. = . € newPasswordâ € œ;
Razón número 5: al exportar un sistema de almacenamiento (por ejemplo, un .script .SQL muy bueno) usted. pueden. obtener .definer ..database .ubicado en .script
En otras palabras y también expresiones, trigger_name ‘. Por lo tanto, si intentan restaurarlo en cada base de datos con un nombre diferente, este elemento fallará. Esperaba que apareciera un solo código de error adicional, ya que la base de datos en la que se encuentra NO apunta realmente a la base de datos que estoy restaurando. Sin embargo, también está obteniendo el error 1235 para esta percepción.
Solución rápida: abra su archivo .sql y reemplace todas las referencias que regresan a EXPORTED_DB_NAME. en el caso de un espacio muy, una cadena de caracteres (es decir, no reemplaza nada).
No use activadores ANTES / ACTUALIZAR en su mesa, como una función de salida (como INSERTAR). No ayude a los activadores AFTER_DELETE, use before_delete en su lugar. No ejecute nombres duplicados. En lugar de abordar Para la misma mesa de póquer que alguien está actualizando o insertando en un disparador de uso, en lugar de una subconsulta específica, consulte OLD y NEW con SET. Si alguna persona está restaurando una base de datos desde su propia copia de seguridad, asegúrese de que la mayoría de los asociados con la copia de seguridad no contengan información clara sobre el fabricante de toda la base de datos (al restaurar a un nombre de base de varios clientes).
Recuerde, aunque crea un desencadenador INSERT, potencialmente a menudo solo puede usar el NUEVO flexible, al crear una causa raíz ACTUALIZAR, puede usar VIEJO y NUEVO, y en un desencadenador DELETE, mi esposo y yo solo podemos referirnos a VIEJO.
Aprobado
La herramienta de reparación ASR Pro es la solución para una PC con Windows que funciona lentamente, tiene problemas de registro o está infectada con malware. Esta herramienta poderosa y fácil de usar puede diagnosticar y reparar rápidamente su PC, aumentando el rendimiento, optimizando la memoria y mejorando la seguridad en el proceso. No sufra más por una computadora lenta: ¡pruebe ASR Pro hoy!