Sur PHP 5.3.13 / MySQL 5.5.21, le code suivant ne fonctionne pas:
if($check_custom_fields_form!=1){
$sql = "CREATE TABLE IF NOT EXISTS ". $table_custom_fields_form ." (
`form_name` longtext NOT NULL,
`field_id` bigint(20) NOT NULL,
FOREIGN KEY (`field_id`) REFERENCES $table_custom_fields (`ID`) ON DELETE CASCADE ON UPDATE CASCADE
) CHARACTER SET utf8 COLLATE utf8_general_ci";
dbDelta($sql);
}
if($check_subscribe_cat!=1){
$sql = "CREATE TABLE IF NOT EXISTS ". $table_subscribe_cat ." (
`subscribe_id` bigint(20) NOT NULL,
`cat_id` bigint(20) NOT NULL,
FOREIGN KEY (`subscribe_id`) REFERENCES ".$wpdb->prefix."tgt_subscription (`ID`) ON DELETE CASCADE ON UPDATE CASCADE,
FOREIGN KEY (`cat_id`) REFERENCES ".$wpdb->prefix."terms (`term_id`) ON DELETE CASCADE ON UPDATE CASCADE
) CHARACTER SET utf8 COLLATE utf8_general_ci";
dbDelta($sql);
}
Le fournisseur de code a suggéré une mise à niveau inférieure vers MySQL 5.1.37 (non, merci) ou la mise à jour suivante:
if($check_custom_fields_form!=1){
$sql = "CREATE TABLE IF NOT EXISTS ". $table_custom_fields_form ." (
`form_name` longtext NOT NULL,
`field_id` bigint(20) NOT NULL,
KEY(field_id)
) CHARACTER SET utf8 COLLATE utf8_general_ci";
dbDelta($sql);
}
if($check_subscribe_cat!=1){
$sql = "CREATE TABLE IF NOT EXISTS ". $table_subscribe_cat ." (
`subscribe_id` bigint(20) NOT NULL,
`cat_id` bigint(20) NOT NULL,
KEY(subscribe_id),
KEY(cat_id)
) CHARACTER SET utf8 COLLATE utf8_general_ci";
dbDelta($sql);
}
Ce qui semble être un moyen plutôt sale de contourner le problème (pas de suppressions / mises à jour en cascade). Donc:
- Dois-je vraiment vivre avec ça jusqu'à ce que dbDelta prenne en charge FOREIGN KEY ?
- Est-il vrai que dbDelta ne fonctionne qu'avec une clé étrangère dans une version MySQL vieille de 3 ans?
Réponses:
Franchement, oui. Mais c'est la beauté de l'open source - n'importe qui est le bienvenu pour poster un patch!
Cependant , son extension pour couvrir d'autres aspects de la conception de schéma entraînerait presque certainement une complexité indésirable et augmenterait les risques d'échec - ce que l'équipe principale considérera fortement à l'avance.
Je prendrais les conseils de @ xav0989 - utilisez
dbDelta
pour son intention (implémentation de table de base, ajouts et ajustements de colonnes), et gérer les fonctionnalités supplémentaires avec$wpdb
.la source