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

SQL-Abfrage ändern bzw. umformulieren

Frage Entwicklung Datenbanken

Mitglied: JosefSepp

JosefSepp (Level 1) - Jetzt verbinden

25.08.2009, aktualisiert 16:41 Uhr, 5224 Aufrufe, 4 Kommentare

Hallo zusammen,

wir haben in unserer Firma zwei voneinander getrennte Kundendatenbanken in eine umgewandelt. Nun haben wir eine gewisse Anzahl von Dubletten in dieser Datenbank und versuchen nun diese herauszufiltern. In der einen Datenbank beginnen die Kundennummern mit einer 17, in der anderen Datenbank beginnen die Kundennummern mit einer 19. Nachfolgend meine SQL-Abfrage:

select count (*) as doppelt, name1, plz, strasse

from kunden


where (kundnr LIKE '17%'
OR kundnr LIKE '19%')
AND Aktivflag = 1

having count (*) > 1



group by name1, plz, strasse
order by doppelt desc, name1


In dieser Abfrage werden dann alle Kunden herausgefiltert, welche den selben Namen, PLZ und Strasse haben. Wenn ich jedoch noch zusätzliche Informationen zu den Kunden haben möchte, müsste ich in der Select-Anweisung mehr Spalten hinterlegen, was wiederrum das Ausgabeergebnis verringert.

Das optimale Ergebnis sollte so sein:

Kunde PLZ Strasse Spalte1 Spalte2 Spalte3
Horst 94491 Weg 1 abc def ghi
Horst 94491 Weg 1 xyz ghi tzu
Horst 94491 Weg 1 jkl zui tzu
Xaver 94469 Ort 2 rts qwe asd
Xaver 94469 Ort 2 ert hjk sdf

Die-SQL-Abfrage soll alle mehrfach angelegten Kunden ausgeben, welche den gleichen Namen, PLZ und Strasse haben. Zusätzlich sollten noch beliebig viele Spalten angegeben werden können.

Datenbank: Oracle 10g (10.2.0.3)

Bin für jede Hilfe dankbar.

Mit freundlichen Grüßen

JosefSepp
Mitglied: Biber
25.08.2009 um 17:23 Uhr
Moin JosefSepp,

für Deine Anforderung brauchst du ja noch einen Join mehr:

01.
 
02.
SELECT k.* FROM Kunden k,  
03.
(select count (*) as doppelt, name1, plz, strasse 
04.
from kunden 
05.
where (kundnr LIKE '17%' 
06.
OR kundnr LIKE '19%') 
07.
AND Aktivflag = 1 
08.
having count (*) > 1 
09.
group by name1, plz, strasse 
10.
) doppelkunde 
11.
WHERE 
12.
K.name1=doppelkunde.kunde AND 
13.
k.Plz=doppelkunde.plz AND 
14.
k.Strasse=doppelkunde.strasse 
15.
ORDER BY k.name1, K.plz, k.strasse, k.kundnr
[ungetestet]



Grüße
Biber

[Edit] Tippfehlerkorrektur: "name1" statt "kunde" und "strasse" statt "str" beim group by. [/Edit]
[Edit2] Jetzt noch mit dem überlesenen ORDER BY DoppelCOUNT:
01.
SELECT doppelkunde.doppelt, k.* FROM Kunden k,  
02.
(select count (*) as doppelt, name1, plz, strasse 
03.
from kunden 
04.
where (kundnr LIKE '17%' 
05.
OR kundnr LIKE '19%') 
06.
AND Aktivflag = 1 
07.
having count (*) > 1 
08.
group by name1, plz, strasse 
09.
) doppelkunde 
10.
WHERE 
11.
K.name1=doppelkunde.kunde AND 
12.
k.Plz=doppelkunde.plz AND 
13.
k.Strasse=doppelkunde.strasse 
14.
ORDER BY doppelkunde.doppelt, k.name1, K.plz, k.strasse, k.kundnr
[/Edit2]
Bitte warten ..
Mitglied: filippg
25.08.2009 um 20:57 Uhr
Hallo,

dein Problem ist, dass du alle Spalten, die im SELECT stehe auch im GROUP haben musst? Und dann nur noch die Ausgegeben bekommst, die tatsächlich _alles_ gleich haben (auch die zusätzlichen Spalten, die du einfach informativ ausgeben willst)? Dann solltest du aus count(*) ein count(strasse) machen.

Gruß

Filipp
Bitte warten ..
Mitglied: JosefSepp
26.08.2009 um 07:59 Uhr
Danke für die beiden Antworten. Werde beide gleich ausprobieren.
Bitte warten ..
Mitglied: JosefSepp
26.08.2009 um 10:40 Uhr
Der Vorschlag von Biber war bis auf einen kleinen Fehler perfekt. (K.name1=doppelkunde.kunde). Danke.

Der Vorschlag von filippg lieferte mir leider keine Ergebnisse. Trotzdem vielen Dank für deinen Vorschlag.
Bitte warten ..
Neuester Wissensbeitrag
Ähnliche Inhalte
Datenbanken
gelöst SQL-Abfrage - DISTINCT - letztes Datum (3)

Frage von emeriks zum Thema Datenbanken ...

Datenbanken
SUM oder AVG in SQL Abfrage dauert viel zu lange warum? (5)

Frage von samet22 zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage mit MAX() (9)

Frage von FrAmEr zum Thema Datenbanken ...

Datenbanken
gelöst Schleifen in SQL-Abfrage bei 2 Tabellen (2)

Frage von Aximand zum Thema Datenbanken ...

Heiß diskutierte Inhalte
Windows Userverwaltung
Ausgeschiedene Mitarbeiter im Unternehmen - was tun mit den AD Konten? (33)

Frage von patz223 zum Thema Windows Userverwaltung ...

LAN, WAN, Wireless
FritzBox, zwei Server, verschiedene Netze (21)

Frage von DavidGl zum Thema LAN, WAN, Wireless ...

Viren und Trojaner
Aufgepasst: Neue Ransomware Goldeneye verbreitet sich rasant (20)

Link von Penny.Cilin zum Thema Viren und Trojaner ...

Windows Netzwerk
Windows 10 RDP geht nicht (18)

Frage von Fiasko zum Thema Windows Netzwerk ...