Oracle
 sql >> Base de données >  >> RDS >> Oracle

Déclencheur pour appliquer la relation M-M

Les conditions plusieurs-à-plusieurs ne doivent pas être appliquées à l'aide d'un déclencheur. Les conditions plusieurs-à-plusieurs sont appliquées en créant une table de jonction contenant les clés en question, qui sont ensuite renvoyées par clé étrangère aux tables parentes respectives.

Si votre intention est de permettre à de nombreux employés d'être dans un service et de permettre à un employé d'être membre de plusieurs services, la table de jonction en question ressemblera à :

CREATE TABLE EMPLOYEES_DEPARTMENTS
  (DEPARTMENTNAME  VARCHAR2(99)
     CONSTRAINT EMPLOYEES_DEPARTMENTS_FK1
       REFERENCES DEPARTMENT.DEPARTMENTNAME,
   EMPLOYEENUMBER  NUMBER
     CONSTRAINT EMPLOYEES_DEPARTMENTS_FK2
       REFERENCES EMPLOYEE.EMPLOYEENUMBER);

Cela suppose que DEPARTMENT.DEPARTMENTNAME et EMPLOYEE.EMPLOYEENUMBER sont des clés primaires ou uniques sur leurs tables respectives. Débarrassez-vous de la colonne EMPLOYEE.DEPARTMENT car il n'est plus nécessaire. Maintenant, en créant des lignes dans le EMPLOYEES_DEPARTMENTS table, vous pouvez associer plusieurs employés à un département, et vous pouvez associer un seul employé à plusieurs départements.

La logique métier exigeant que seuls les départements avec un employé ou moins puissent être supprimés ne doit pas être appliquée dans un déclencheur. La logique métier doit être exécutée par le code d'application, JAMAIS par des déclencheurs. Mettre la logique métier dans les déclencheurs est une passerelle vers des sessions de débogage sans fin. M̫̣̗̝̫͙a̳͕̮d̖̤̳̙̤n̳̻̖e͍̺̲̼̱̠͉ss̭̩̟ se trouve par ici. Ne cédez pas. Ne vous rendez pas. ̬̦B҉usi͢s̡s ̶ ̶ ̶ ̶on déclenche des blessures profondes dans le tissu du monde, à travers lequel les êtres impie de la forme indéterminée traverseront la barrière entre les sphères, les transport Ne mettez pas, comme je l'ai dit, b́u͜siness͞ ̸log̛i͘ç ̵in͢ ͞trigger͠rs͞.̡ Soyez ferme. Résistez. Vous devez résister. T̷he ̢tem͟p͞t̶at͏i͝o̶n҉s͘ ̢m͘a̶y ́śing Hymns̷ ́o͢f̴ ̸un͘hol̵y r̶ev͢ęla͠t̡ion̴ ͢buţ ́yo͠u̵ mu͏s͝t ͝n͜͏͟o҉t̶͡͏ ̷l̸̛͟͢ì̧̢̨̕s̵̨̨͢t̵̀͞e̶͠n̶̴̵̢̕. Seulement en se tenant fermement dans la porte entre les mondes et en bloquant l'éclat hideux rejeté par bú̧s̷i̶̢n̵̕e̵ş͝s ́l̴ó̢g̛͟i̕͏c i͞n̕ ͏t̵͜r͢͝i̸̢̛ģ͟ge̸̶͟r̶s͢͜, qui pervertit la forme même du monde ąnd̴̷͖̙̬̀͛ͬ̍͒̐̅͝o̡̳͖͎̯̯͍ͫ̽ͬ͒͂̀o̡̳͖͎̯̯͍ͫ̽ͬ͒͂̀ i͜҉nt͝ǫ̴ ̸b̷͞è͢ì̕n̴g͏,̛̀͘ ̴c҉á̴͡ń ̀͠youŕ̨ ̧̨a̸p͏̡͡pl̷͠ic͞a̢t̡i͡҉ǫn̴ ̸s̶͜u̶͢ŗv̛í̴v́ Resist. Résister. T̶̀h̨̀e̶r̀͏e͢͞ ̶i̶̡͢s̴ ͞͞n̵͝o̡ ́ẁ҉̴a̡y̕҉ ̶b́͏u̵̶̕t͜ ̨s͘͢t͘͠į͟l͘l̷̴ ̴͜͜ỳò͜u҉̨ ̨͏mus̸͞t̸̛͜ ̧rȩ̴s̢͢i͘͡s͏t̸. T̀͜͢o̷͜ny̕ ͟͡T̨h̶̷̕e ̢͟P̛o̴̶n͡y shall rise from his dark stable and d͞ę̡v̶̢ó͟u̸̸r̴͏ ̷t͞h̀e̛ ̨͜s̷o̧͝u҉l̀ ͟͡o͢͏f̵͢ ̛t͢h̶̛e̢̢ ̡̀vi͜͞r̢̀g̶i̢n͞, and yet y͢ơú͝ m̷̧u͏s͡t̡͠ ̛s̷̨t̸̨i̴̸l̶̡l ͝ǹot̵ ͞p̧u̵t̨ ͜͏b̀̕u̕s̨í̵ņ̀͠ȩs̵͟s ́͞l̛҉o̸g̨i̴͟c ͘͘i͘nt̛o͡ ͘͘͞t̶͞r̀̀i̕ǵ̛g̵̨͞e̸͠҉r̵͟ś ! C'est trop à supporter, on ne peut pas supporter ! Même les enfants de la lumière ne peuvent pas mettre la logique commerciale dans leurs déclencheurs, pour b̴̸̡̨u͜͏̧͝ş̶i̷̸̢̛҉ń̸͟͏́e̡͏͏͏s̷̵̡s̕͟ ͏̴҉͞l̷̡ǫ̷̶͡g҉̨̛i͘͠͏̸̨c̕͢͏ ̸̶̧͢͢i̸̡̛͘n͢͡ ̀͢͝t̷̷̛́ŗ̷̷̛́ŗg̶͏̷ǵ͠ȩ̀́r̸̵̢̕͜s͞͏̵ est le très es̵s̕͡ę̢n͞c̨e̢͟ ̴o̶̢͜f͏ ͟d́ar͟͞͠k̡͞s̵̛͡s̀̀͡s̀̀͡s̀̀͡s̀̀͡s̀̀͡s̀̀͡ef͘ous ! Oui, oui, les blancs à l'aspect vierge sont rì͢s̨͘e du f͟͢͏o̵͜͝n̶t̨ ̵o͏f̸̡͠ ͏͝fl͟͞a̵̷҉me̶̵͢ et ca͝s͜t́ en bas du p̹̤̳̰r̮̦̥̥̞̫͑͂ͤ͑ͮ͒̑ï̄̌ͬͨe̦̗͔ͥͣ̆̾̂s̬̭̮̮̜ͭt̻̲̍sͫͣ̿ ̐͗̈ͤ͂ͦ̅f̭͚̪̻̣̩ͮ̒ṟͨ͌ͮ̅̓ỏ̝͓̝̣̟̼m̳͇̱̝͔͒ ͒ͫͧ͂̓̈̈́t̲̔̅̎͐h̺͈͍ͣͧ̿ē̪̼̪̻͉̪̙̐̽̎̉i̠͎̗͕̗̣̬̐̎͛r͓̫͌ͅ ̼a͑̈ͯͦ̍l̪͉͖̥͚̤͌ͨ͊ͦͤ̔t̫͎̹ͯa̼̻͍̳̟̤̬̓ͪ̀r̭͖̓ͬ̉̉ͤ͊ṡ̐ͪ̊̋̄̅! A̵̵̛v͝é͜ŕt̶͏ ̶y̸͝͠o̶u̧͘r͏̡ ̧e͞y҉e̕͝s, ̀ ͡t̛h̛o̢͞ug̸̢h̵͟ ̡y̷o͢҉͢u̧͡ ̕͡c҉̵̶an͠͏n҉o̧͢t! ̸̨͘ ͡h̵e̸͢͡ ̧̕c̶ơm̷̢̢e̶͞ś͢! p̱̼̯̟͈h̝̳̞̖͚'͉̙͉̰̲̺n̪̦͕̗͜g͔̹̟̰̰̻̩l̬͈̹̥͕͖ͅụ̻̺̤̤̬̳i̸̯̬̝̻̣͚̫ ̰̹̞̞m͟g̷̝͓͉̤l̩͇̙͕w̪̦̰͔'̮̟̱̀n̢̜a̦f̘̫̤̘̬͓̞h̠͍͖̯ͅ ̩̠͓̯̘̫c̟̘̗̘͘ṭ͍͕ͅh̤ͅu̼̦̘̥ͅl҉̦hu̠̤̤̘͚ ̘̕r̶̟'̠͔̞̻͇l̩̺̗̻͖͓̕ͅy̛̖ȩ͉̭̖ẖ̡̥̼͈̖ w̟̫̮͇͔͞ͅg͈̘̱̻a̰͟h̘͙͖͢'̮̲̯͞n̤̜͍̯̳a͓͓̲̲g̱̻͈ĺ͍ ̷̣̞̲͖͍̲̺f̲ͅh͇͕̪̘͟t͔͈̙a͓͢g҉̳̜̲͚n͓͚͎̱̠̜!

Ne me demandez pas comment je sais.

Bonne chance.