CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[SQL] Foreign Key, On Update Cascade...

niko2805
niko2805
Niveau 9
30 septembre 2011 à 14:54:26

Bonjour,

Voila j'ai la Table MySQL suivante :
CREATE TABLE `playlist_line` (
`id` VARCHAR(40) NOT NULL,
`day_id` VARCHAR(40) NOT NULL,
`line_key` INT(40) NOT NULL AUTO_INCREMENT,
`parent_key` INT(40) NULL DEFAULT '0',
`prior_key` INT(40) NULL DEFAULT '0',
`line_type` INT(1) NULL DEFAULT '0',
`tcin` INT(11) NULL DEFAULT '0',
`duration` INT(11) NULL DEFAULT '0',
...
PRIMARY KEY (`id`),
INDEX `FK_playlist_line_day` (`day_id`),
INDEX `line_key` (`line_key`),
INDEX `parent_key` (`parent_key`),
CONSTRAINT `FK_playlist_line_day` FOREIGN KEY (`day_id`) REFERENCES `day` (`id`) ON UPDATE CASCADE ON DELETE CASCADE,
CONSTRAINT `FK_playlist_line_playlist_line` FOREIGN KEY (`parent_key`) REFERENCES `playlist_line` (`line_key`) ON UPDATE CASCADE ON DELETE CASCADE
)
ENGINE=InnoDB

Voici mon problème, quand je fait un update d'un ligne ou je change le champ 'line_key' jai une erreur SQL:
"SQL Error (1451): Cannot delete or update a parent row: a foreign key constraint fails: 'FK_playlist_line_playlist_line'

pourtant avec le on update cascade il ne devrait pas changer la Key dans les lignes fils ?

merci

_skip
_skip
Niveau 10
30 septembre 2011 à 15:14:29

Oui mais sauf erreur, c'est une limitation d'innoDB ça...

niko2805
niko2805
Niveau 9
30 septembre 2011 à 15:23:07

Merci pour ta réponse, c'est a dire une limitation d'innoDB ? tu parle de l'erreur ? ou des ON UPDATE CASCADE ?

_skip
_skip
Niveau 10
30 septembre 2011 à 15:33:47

Je dirai surtout la façon dont innodb gère les cascades avec des contraintes parent-enfant sur la même table n'est pas au point.

Je profite aussi de te dire, tes types de données ont l'air fantaisistes : INT(40)?.

niko2805
niko2805
Niveau 9
30 septembre 2011 à 15:38:49

Merci, sinon oui INT(40) car les références généré par le systeme sont des suite de 32 chiffres pour les keys ... ca ce n'est pas de mon fait :p

_skip
_skip
Niveau 10
30 septembre 2011 à 16:01:14

Ca peut pas rentrer puisque qu'un INT par défaut c'est environ 2 milliards.

niko2805
niko2805
Niveau 9
30 septembre 2011 à 17:49:32

Merci, c'est corrigé en varchar(40)

Sous forums
  • Aide à l'achat Mac
  • Création de Jeux
  • Linux
  • Programmation
  • Création de sites web
  • Internet
  • Steam Deck
  • Macintosh
  • Hardware
La vidéo du moment