Top-Themen

Aktuelle Themen (A bis Z)

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

MySQL-Tabelle bereinigen mit DELETE - USING - JOIN

Mitglied: oliPro

oliPro (Level 1) - Jetzt verbinden

18.02.2010, aktualisiert 07:53 Uhr, 4866 Aufrufe, 3 Kommentare

Verknüpfte Tabellen bereinigen, wenn es einen Datensatz (der eigentlich verknüpft sein sollte) nicht gibt.

MySQL-Client-Version: 5.0.22

Vorhanden ist Tabelle A und Tabelle B, die über X miteinander verknüpft sein sollten.
Jetzt möchte ich prüfen, ob das auch immer der Fall ist.
Wo es nicht so ist, soll der komplette Eintrag aus Tabelle A gelöscht werden.

Mein Problem liegt darin, dass ich nicht weiss, wie ich abfragen soll.
So in der Art war mein Ansatz ...

DELETE FROM A
USING A, B
WHERE B.X nicht vorhanden
Mitglied: Biber
18.02.2010 um 09:37 Uhr
Moin oliPro,

da gibt es für geschätzte n mySQL-Anwender circa n hoch 3 verschiedene Möglichkeiten.
Mit LEFT JOIN, mit NOT EXISTS, mit Unterabfrage...

Würde ich von der Satzanzahl und Kardinalität der Daten in A und B abhängig machen.
Vermutlich das kürzeste wäre

01.
DELETE FROM A 
02.
 WHERE A.X <> ANY  (SELECT X FROM B); 
03.
-- oder gleichwertig das eher ungebräuchliche SOME 
04.
DELETE FROM A 
05.
 WHERE A.X <> SOME  (SELECT X FROM B);
Aber natürlich erstmal testen, was herauskommt bei einem
01.
SELECT A.* FROM A 
02.
 WHERE A.X <> ANY  (SELECT X FROM B);
Grüße
Biber
Bitte warten ..
Mitglied: oliPro
18.02.2010 um 09:47 Uhr
Hallo Herr Biber ...

danke für den Tipp! Leider liefern beide Methoden (AND + SOME) alle Datensätze zurück

Gruß, oliPro
Bitte warten ..
Mitglied: Biber
18.02.2010 um 10:31 Uhr
Moin oliPro,

deshalb habe ich ja geschrieben "Aber natürlich erstmal testen, was herauskommt bei einem SELECT.."

Dann nehmen wir eine der vielen anderen Möglichkeiten
01.
SELECT A.*   
02.
FROM A 
03.
LEFT JOIN B on A.X = B.X 
04.
WHERE B.X  IS NULL ;
-oder-
01.
SELECT A.* 
02.
FROM A 
03.
WHERE A.X NOT IN (SELECT B.X FROM B);
Wenn das plausibler aussieht, dann "SELECT A.*" durch "DELETE FROM A" ersetzen.

Grüße
Biber
Bitte warten ..
Ähnliche Inhalte
Datenbanken
MySQL - Join
Frage von ThoomaasDatenbanken4 Kommentare

Hallo alle zusammen! Ich habe zwei Tabellen in meiner Datenbank. Die eine beinhaltet Teams und einen Code zum Team ...

Datenbanken
Join über drei Tabellen
gelöst Frage von KimaroDatenbanken5 Kommentare

Hallo Admins, ich versuche gerade eine SQL Abfrage für meine Website zu basteln, aber irgendwie klappt das nicht so ...

Datenbanken
Inner join über 3 Tabellen
Frage von Fitzel69Datenbanken10 Kommentare

Hallo zusammen, ich habe folgendes Problem: Ich muß aus unserem ERP System mehrere Infos heraus ziehen. Hierfür benötige ich ...

Datenbanken
MySQL Abfrage um JOIN erweitern
gelöst Frage von datadexxDatenbanken14 Kommentare

Hallo SQL Experten, ich bräuchte mal wieder eure Hilfe Ich habe folgende Abfrage für eine Statistik welche soweit auch ...

Neue Wissensbeiträge
Administrator.de Feedback
Update der Seite: Alles zentriert
Information von Frank vor 53 MinutenAdministrator.de Feedback4 Kommentare

Hallo User, die größte Änderung von Release 5.8 ist das Zentrieren der Webseite (auf großen Bildschirmen) und ein "Welcome"-Teaser ...

Humor (lol)

WhatsApp-Nachrichten endlich auch per Bluetooth versendbar

Information von BassFishFox vor 18 StundenHumor (lol)4 Kommentare

Genau darauf habe ich gewartet! ;-) Der beliebte Messaging-Dienst WhatsApp erhält eine praktische neue Funktion: Ab dem nächsten Update ...

Google Android

Googles "Android Enterprise Recommended" für Unternehmen

Information von kgborn vor 1 TagGoogle Android3 Kommentare

Hier eine Information, die für Administratoren und Verantwortliche in Unternehmen, die für die Beschaffung und das Rollout von Android-Geräten ...

Sicherheit

Intel gibt neue Spectre V2-Microcode-Updates frei (20.02.2018)

Information von kgborn vor 1 TagSicherheit

Intel hat zum 20. Februar 2018 weitere Microcode-Updates für OEMs freigegeben, um Systeme mit neueren Prozessoren gegen die Spectre ...

Heiß diskutierte Inhalte
Server-Hardware
Welche Rolle spielt Design bei Enterprise IT Hardware?
Frage von ApolloXServer-Hardware17 Kommentare

Ich arbeite für einen internationalen Elektronikhersteller in der Forschung und meine Aufgabe ist es, Feedback von Nutzern in Hinsicht ...

Windows Netzwerk
WSUS4 und Windows 10 Updates automatisch installieren
Frage von sammy65Windows Netzwerk15 Kommentare

Hallo miteinander, ich habe mit einen neuen WSUS Server aufgesetzt Server 2016 darauf einen aktuellen WSUS. Grund, wir stellen ...

Switche und Hubs
Cisco SG350X-48 AdminIP in anderes VLAN
Frage von lcer00Switche und Hubs14 Kommentare

Hallo zusammen, ich habe ein Problem mir einem Cisco SG350X-48 bei der Erstinstallation wurde eine IP 192.168.0.254 (Default VLAN ...

Speicherkarten
Vergessliche USB-Sticks?
Frage von hanheikSpeicherkarten14 Kommentare

Ich habe in den letzten Tagen 500 USB-Sticks mit Bilddateien bespielt. Obwohl ich die Dateien mit größter Sorgfalt kopiert ...