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, 5230 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.

mfg

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
Off Topic

"Ich habe nichts zu verbergen"

(2)

Erfahrungsbericht von FA-jka zum Thema Off Topic ...

Ähnliche Inhalte
Datenbanken
gelöst Hilfe bei SQL-Abfrage (5)

Frage von emeriks zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage mit "kleiner gleich" funktioniert nicht (2)

Frage von derSESO zum Thema Datenbanken ...

Datenbanken
gelöst SQL Abfrage - Ausgabe von Person mit Privat- und Dienstadresse (3)

Frage von CBruns zum Thema Datenbanken ...

VB for Applications
Anpassungsdatei verschiedene Parameter (Hostname, SQL, Registry) ändern (3)

Frage von MiMa89 zum Thema VB for Applications ...

Heiß diskutierte Inhalte
Linux Netzwerk
gelöst DHCP vergibt keine Adressen (31)

Frage von Maik82 zum Thema Linux Netzwerk ...

Exchange Server
gelöst Bestehende eMails autoamatisch weiterleiten (22)

Frage von metal-shot zum Thema Exchange Server ...

Switche und Hubs
LAG zwischen SG300-Switches macht Probleme. Wer weiß Rat? (20)

Frage von White-Rabbit2 zum Thema Switche und Hubs ...

Apache Server
gelöst Lets Encrypt SSL mit Apache2 (20)

Frage von banane31 zum Thema Apache Server ...