Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

NzuM Beziehung Updaten

Frage Entwicklung Datenbanken

Mitglied: djfflow

djfflow (Level 1) - Jetzt verbinden

07.07.2009, aktualisiert 16:34 Uhr, 2956 Aufrufe, 6 Kommentare

Ich habe 3 Tabellen Film, Schauspieler, FiSc.
Die Tabellen Schauspieler und Film stehen über FiSc in einer n:m Beziehung.
Ich lasse nun per PHP zu einem Film alle Schauspieler ausgeben.
Nun möchte ich auch bearbeiten können, welcher Schauspieler in einem Film mitgespielt hat.

Wie kann ich es erreichen, dass entweder ein Datensatz hinzugefügt, upgedatet oder gelöscht wird?

Die einfachste Lösung wäre ja alle Verbindungen zu einem Film zu löschen und dann nachher neueinzutragen, aber das muss doch auch eleganter gehen?
Mitglied: Biber
07.07.2009 um 18:34 Uhr
Moin djfflow,

hast Du denn auch ein konkretes Datenbankblech drunter oder arbeitest Du eher abstrakt?

Und wo ich grad beim Nachfragen bin:
a)
Die einfachste Lösung wäre ja alle Verbindungen zu einem Film zu löschen und dann nachher neu einzutragen
Ist das ein Hella-von-Sinnen-Zitat oder bist Du allein zu dieser Einsicht gekommen?
b) wo genau ist Dein Problem jetzt?
Wenn Du einen vorhandenen Film ausgewählt hast (den mit der ID 77 zum Beispiel), dann kannst Du doch aus der Zuordnungstabelle FiSc alle SchauspielerInnen selektieren, die bereits diesem Film zugeordnet sind.
Aus den vorhandene kannst Du selektiv "löschen"; aus den noch nicht diesem Film zugeordneten kannst du neue hinzufügen.
Und du kannst auch "ändern" (einen vorhandenen Schaupieler löschen und statt dessen einen anderen hinzufügen)

Wo genau ist jetzt Dein Problem?
Ich meine, so etwas machen Delmenhorster ohne Datenbank...

Grüße
Biber
Bitte warten ..
Mitglied: djfflow
08.07.2009 um 09:31 Uhr
Hallo Biber,

ich bin leider kein Profi für DBs.
Die Datenbank ist MySQL, falls du das mit "Datenbankblech" meinst.

Ich lese mit PHP/HTML zu einem Film alle Schauspieler in ein Multiples Select/Option Feld aus und lasse alle Schauspieler markieren die mit dem Film in Verbindung stehen.

Jetzt kann es natürlich sein, dass ich statt 2 Schauspielern 3 auswähle, oder statt 2 nur noch 1en, oder bei 2 Schauspielern 2 andere auswähle.

Meine Frage ist jetzt, kann ich diese 3 Fälle mit einem SQL-Befehl abarbeiten oder wie mache ich das?
Bitte warten ..
Mitglied: Biber
08.07.2009 um 13:55 Uhr
Moin djfflow,

danke für die Antwort.
Ja, mit "Datenbankblech" meinte ich mySQL in Deinem Fall.

Wenn ich Dich richtig verstehe, möchtest Du die Programmlogik "Ist für die Zuordnung bzw. Abwahl SchauspielerX -zu-Film-Y ein INSERT, ein Update oder ein Delete nötig?" gar nicht erst auf PHP-Seite implementieren, sondern willst es gleich der DB aufdrücken?

Lässt sich auch machen, allerdings dann über eine Triggerlösung.

Dann kannst Du z.B. alle 4 Sätze, die in Deinem multiplen Select am Ende markiert sind als INSERT an die DB schicken.
Und vorher alle vorhandenen Sätze Fi-Sc zu diesem Film löschen. (Jetzt versteh ich erst, was Du mit diesem ersten Satz gestern gemeint haben könntest.)

Ich halte dieses Vorgehen nicht für besonders elegant und auch nicht performant, aber machbar ist es.

Dann wäre jetzt erstmal eine Suche "mySQL+Trigger" Deinerseits nötig, damit Du Dir dieses Vorgehen vorstellen kannst.

Und abschätzen kannst, was wohl schneller zusammenzuschreddern ist - die Trigger oder die unterschiedliche Fallbehandlung Insert/Delete auf PHP-Appz-Seite.

Grüße
Biber
Bitte warten ..
Mitglied: djfflow
08.07.2009 um 14:34 Uhr
Hallo Biber,

wenn du meinst, das sich der Aufwand wenig lohnt werde ich es auf PHP Seite lösen.
Ich hatte gehofft, das man das relativ einfach mit mysql abbilden kann.

Für die Umsetzung würde ich die alten und die neuen Werte in je ein Array schreiben und dann vergleichen. und je nach Fall dann das passende Query auslösen.

Oder hast du eine bessere Idee?
Bitte warten ..
Mitglied: Biber
08.07.2009 um 15:24 Uhr
Moin djfflow,

nein, da hätte ich keine bessere Idee. Würde ich genauso angehen.

Ist ja aus meiner Sicht auch wirklich "Programmlogik" und von daher natürlich am besten
  • in einer Programmiersprache statt einer Datenmanipulationssprache zu lösen (PHP statt SQL)
  • und zweitens besser im Hauptspeicher lösbar als auf der Festplatte ("mach eine fallunterscheidung" statt "lösche alle Sätze, lege dann alle neu an")

Grüße
Biber
Bitte warten ..
Mitglied: djfflow
08.07.2009 um 15:32 Uhr
Ok.
Dann vielen Dank für deine Antworten
Bitte warten ..
Neuester Wissensbeitrag
Internet

Unbemerkt - Telekom Netzumschaltung! - BNG - Broadband Network Gateway

(3)

Erfahrungsbericht von ashnod zum Thema Internet ...

Ähnliche Inhalte
Exchange Server
gelöst Exchange 2013 lässt sich nicht Updaten (9)

Frage von onkel87 zum Thema Exchange Server ...

Microsoft
gelöst Windows 10 1607 Anniversary Update manuell herunterladen und updaten (7)

Frage von thomasreischer zum Thema Microsoft ...

Windows 10
gelöst Treiber unter Windows (7,8,10) per Script auf Remote-PCs updaten (4)

Frage von MrCount zum Thema Windows 10 ...

Microsoft
gelöst Win8 Pro Rechner auf Win 10 pro updaten (6)

Frage von thomasreischer zum Thema Microsoft ...

Heiß diskutierte Inhalte
Windows Server
Outlook Verbindungsversuch mit Exchange (15)

Frage von xbast1x zum Thema Windows Server ...

Microsoft Office
Keine Updates für Office 2016 (12)

Frage von Motte990 zum Thema Microsoft Office ...

Grafikkarten & Monitore
Tonprobleme bei Fernseher mit angeschlossenem Laptop über HDMI (11)

Frage von Y3shix zum Thema Grafikkarten & Monitore ...