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

Doppelte Werte aus SQL Datenbank löschen

Mitglied: Totty

Totty (Level 1) - Jetzt verbinden

28.09.2009 um 15:36 Uhr, 9226 Aufrufe, 3 Kommentare

Problem in SQL Tabelle. Doppelte Zeilen vorhanden.

Hallo Froum,

ich habe ein Problem. In einer Datenbank auf unserem SQL-Server ist es passiert, dass wir nun 2 Zeilen mit exakt gleichem Eintrag haben.

93157e5a608161b898483cb7d6b024ee-bild_1 - Klicke auf das Bild, um es zu vergrößern

Wenn ich nun die eine Zeile löschen will, kommt folgende Fehlermeldung

21577020c265a09c7f0472d719705f4e-bild_2 - Klicke auf das Bild, um es zu vergrößern

auch ein verändern des Inhaltes ist nicht mehr möglich. Kann mir vielleicht einer weiterhelfen und sagen, wie ich die doppelte Zeile wegbekommen kann?


Gruß Totty
Mitglied: maretz
28.09.2009 um 15:59 Uhr
Moin,

kannst du ein wenig Programmieren? Dann würde ich mir ein kleines Programm einlesen welches alle Datensätze einmal per "UNIQUE" einliest (somit sind die doppelten da nicht drin). Danach in einer schönen Schleife beigehen und erst einmal alle Datensätze löschen die dieselben Daten haben wie der aktuelle Datensatz - und dann den aktuellen Datensatz einmal eintragen...

Allerdings: Für diese Lösung solltest du SEHR genau wissen was die Tabelle macht und wie die verlinkt ist -> da es ggf. auch zu extremen problemen führen kann...

und bitte dran denken: Eine Datenbank kennt normal keine Undo-Funktion!
Bitte warten ..
Mitglied: Biber
28.09.2009 um 19:08 Uhr
Moin Totty,

um die Daten konsistent zu bekommen, wird nun nicht unbedingt Programmiererfahtung oder gar ein Programm nötig sein.
Aber von der Strategie her wird Dir -wie maretz schrieb- nichts anders übrig bleiben als BEIDE Sätze zu löschen.
Ober eben eine Kopie der Tabelle mit "Select Feld1, Feld2,..Feldn group by Feld1, Feld2,..Feldn Into kopieTabelle" zu erstellen, die Originaltabelle zu trunctaten und zurückzuspielen.

Aber viel interessanter:
  • Wie konnte das passieren bzw. wieso sind da keine PrimaryKeys drauf?
  • Das sieht doch nach einer Import-tabelle aus... wieso wird die ungefiltert blind übernommen?
  • Ist das eine "produktive" Tabelle und sind eher 300 oder eher 300 Mio Datensätze drin?
  • Hast Du denn die Rechte zum Anlegen einer neuen Tabelle, zum Inserten und Deleten auf der Alten?

Fass bitte nichts an, bevor wir wissen, welchen Schaden ein "uupps, da war noch ein Tippfehler drin" anrichten könnte.

Grüße
Biber
Bitte warten ..
Mitglied: nxclass
29.09.2009 um 09:04 Uhr
.. ich würde mal prüfen ob die SYSROWID eindeutig ist.

Und / Oder alle Datensätze die SYSROWID IS NOT NULL in eine neue Tabelle übertragen.
01.
CREATE TABLE `tmp_table` SELECT * FROM `table` WHERE `SYSROWID` IS NOT NULL;
Die neue Tabelle kann dann geprüft werden um dann die alte zu ersetzen.
Bitte warten ..
Ähnliche Inhalte
Datenbanken
MS SQL Cache Datenbank löschen
gelöst Frage von GahmuretDatenbanken5 Kommentare

Hallo zusammen, wie lösche ich den Cache einer MS SQL Datenbank? Bevorzugt über ein SQL Statement. VG Gahmuret

Datenbanken

Doppelten Datensatz suchen und Wert erhöhen

gelöst Frage von dax4funDatenbanken1 Kommentar

Moin, es gingen mir schon alle Suchbegriffe beim googlen aus um eine SQL Abfrage zu basteln die folgendes tun ...

Microsoft Office

Wenn Wert doppelt, dann Zeile darunter einfügen

gelöst Frage von PhilosophMicrosoft Office12 Kommentare

Hallo alle zusammen! Ich habe eine Exceldatei mit 5 Spalten. In Spalte A befinden sich Kundennummern, in Spalte B ...

PHP

Werte in einer sql Spalte addieren

gelöst Frage von helmuthelmut2000PHP13 Kommentare

Hallo, Ich habe folgendes Problem. Ich habe eine PHP Seite mit einer MSSQL Datenbank. Da gibt es eine Tabelle ...

Neue Wissensbeiträge
Sicherheit
Sicherheitsrisiko: Die Krux mit 7-Zip
Information von kgborn vor 9 StundenSicherheit

Bei vielen Anwendern ist das Tool 7-Zip zum Entpacken von Archivdateien im Einsatz. Die Software ist kostenlos und steht ...

Internet

Datendealing im WWW Tracking Methoden immer brutaler

Information von sabines vor 18 StundenInternet

Interessanter Artikel zum Thema Tracking im WWW und die immer "besseren" Methoden des Trackings. Professor Arvind Narayanan (Princeton-Universität) betreibt ...

Erkennung und -Abwehr

Ups: Einfaches Nullzeichen hebelte den Anti-Malware-Schutzt in Windows 10 aus

Information von kgborn vor 1 TagErkennung und -Abwehr

Windows 10 ist das sicherste Windows aller Zeiten, wie Microsoft betont. Insidern ist aber klar, das es da Lücken, ...

Windows 10

Windows 10 on ARM: von Microsoft entfernte Info - Klartext, was nicht geht

Information von kgborn vor 1 TagWindows 10

Windows 10 on ARM ist ja eine neue Variante, die Microsoft im Verbund mit Geräteherstellern am Markt etablieren will. ...

Heiß diskutierte Inhalte
Server
Route-Befehl Unterstützung (unter CMD)
gelöst Frage von FKRR56Server36 Kommentare

Guten Tag , i.M. habe ich Probleme über den CMD-Route-Befehl ein Routing auf einen entfernten Server zuzulassen. Der Server ...

Windows 10
Windows 10 (1709) Tastur und Maus wieder einschalten?
Frage von LochkartenstanzerWindows 1028 Kommentare

Moin, Ich habe von einem Kunden einen Win10-Rechner bekommen, bei dem weder Tastatur noch Maus geht. Die Hardware funktioniert ...

Microsoft
TV-Tipp: Das Microsoft-Dilemma
Information von kgbornMicrosoft17 Kommentare

Aktuell gibt es in Behörden und in Firmen eine fatale Abhängigkeit von Microsoft und dessen Produkten. Planlos agieren die ...

Webbrowser
Welcher Browser ist der Beste?
Frage von justtinWebbrowser15 Kommentare

Hallo Leute Ich habe eine interessante Frage. Mich wurde mal interessieren welcher Browser ist eure meinung nach der beste? ...