La unión de estos dos SELECTs da como resultado el listado de comandos de eliminación y creación de todas las llaves foráneas que existan en la base de datos a la que se está conectado.
select XSQL from ( select 1 as N, concat('alter table ', TABLE_NAME, ' drop foreign key ', CONSTRAINT_NAME, ';') as XSQL from information_schema.TABLE_CONSTRAINTS where TABLE_SCHEMA = database() and CONSTRAINT_TYPE = 'FOREIGN KEY' union select 2, concat('alter table ', a.TABLE_NAME, ' add constraint ', a.CONSTRAINT_NAME, ' foreign key (', b.COLS, ')', ' references ', b.REFERENCED_TABLE_NAME, ' (', b.REF_COLS, ');' ) as XSQL10 from information_schema.TABLE_CONSTRAINTS a inner join ( select b.TABLE_NAME, b.CONSTRAINT_NAME, a.REFERENCED_TABLE_NAME, GROUP_CONCAT(a.COLUMN_NAME ORDER BY a.ORDINAL_POSITION SEPARATOR ', ') as COLS, GROUP_CONCAT(a.REFERENCED_COLUMN_NAME ORDER BY a.ORDINAL_POSITION SEPARATOR ', ') as REF_COLS from information_schema.KEY_COLUMN_USAGE a inner join information_schema.TABLE_CONSTRAINTS b on b.table_schema = database() and a.table_schema = database() and b.CONSTRAINT_NAME = a.CONSTRAINT_NAME and b.CONSTRAINT_TYPE = 'FOREIGN KEY' group by b.TABLE_NAME, b.CONSTRAINT_NAME, a.REFERENCED_TABLE_NAME ) b on a.TABLE_SCHEMA = database() and b.TABLE_NAME = a.TABLE_NAME and b.CONSTRAINT_NAME = a.CONSTRAINT_NAME and a.CONSTRAINT_TYPE = 'FOREIGN KEY' ) x order by N;
Política de PrivacidadÚltima actualización: 23 de diciembre de 2024 |
X |
Tu privacidad es importante para nosotros. En esta política de privacidad, explicamos qué información recopilamos cuando visitas nuestro sitio web y cómo utilizamos esa información.
Este sitio no recopila información personal de los usuarios, excepto cuando un usuario elige voluntariamente comunicarse a través del formulario de contacto. En ese caso, los datos proporcionados (como tu nombre y correo electrónico) se utilizarán únicamente para responder a tu consulta.
Este sitio web utiliza una única cookie esencial llamada PHPSESSID
.
PHPSESSID
se utiliza exclusivamente en la página de contacto para gestionar el funcionamiento del CAPTCHA. Esto garantiza que el formulario de contacto funcione correctamente y evita envíos automáticos o maliciosos.No usamos cookies de análisis ni de seguimiento.
Adoptamos medidas técnicas y organizativas razonables para proteger cualquier información que compartas con nosotros contra el acceso no autorizado, pérdida o alteración.
Nuestro sitio web puede contener enlaces a otros sitios web. No somos responsables de las prácticas de privacidad ni del contenido de dichos sitios.
Nos reservamos el derecho de actualizar esta política de privacidad en cualquier momento. Cualquier cambio será publicado en esta misma página e incluirá la fecha de la última actualización.
Si tienes preguntas o inquietudes sobre esta política de privacidad, puedes comunicarte con nosotros a través de la página de contacto disponible en este sitio web.
Nuestro sitio web cumple con las principales regulaciones internacionales de protección de datos personales para garantizar la privacidad y seguridad de los usuarios. Esto incluye, pero no se limita a, las siguientes leyes:
Si tienes preguntas o dudas sobre el cumplimiento de estas leyes, no dudes en ponerte en contacto conmigo a través de la página de contacto de este sitio web.