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

In MySQL aus einer Ergebnisliste bestimmte Werte extrahieren

Frage Entwicklung Datenbanken

Mitglied: bytecounter

bytecounter (Level 2) - Jetzt verbinden

23.10.2010 um 13:04 Uhr, 3059 Aufrufe, 2 Kommentare

Hallo zusammen,

in Datenbanktabelle 'record' finden sich diverse Aufzeichnungen. Eine Aufzeichnung kann vom Typ 1 bis 10 sein, wobei sich dieser in unregelmässigen Abständen ändert. Dafür gibt es die Tabelle 'recordType' mit folgendem Aufbau:

id
recordId
typeId
validFrom

Wird eine neue Aufzeichnung angelegt, ist in dem Datensatz in 'recordType' 'validFrom' NULL.
Nun ist es aber auch so, dass der Typ teilweise schon im Voraus bekannt ist und entsprechend erfasst wird .Somit kann in der Tabelle 'recordType' zu jeder Aufzeichnung auch mindestens ein Datensatz mit zukünftigem Datum stehen.

recordType:
id recordId typeId validFrom
1 1 1 NULL
2 2 1 NULL
3 1 2 2010-10-18
4 1 3 2010-10-29
5 2 2 2010-11-30
6 3 1 NULL
7 1 4 2010-10-24
8 1 5 2010-11-01
9 4 2 NULL

Nun kann ich mit
01.
SELECT typeId FROM `recordType` WHERE recordId=1 AND (validFrom < CURDATE() OR validFrom is NULL) ORDER BY validFrom DESC LIMIT 0,1
den aktuellen Typ einer Aufzeichnung abfragen.

Aber wie realisiere ich ein halbwegs performantes SQL Statement, dass mit alle Aufzeichnungen ausgibt, die aktuell (also im Augenblick der Abfrage) von einem betsimmten Typ sind?

Beispiele:

Gemäß obiger Tabelle müsste ich (wenn heute der 2010-10-19 ist) bei
typeId 1 die Aufzeichnungen mit folgenden Id's erhalten: 2
typeId 2 die Aufzeichnungen mit folgenden Id's erhalten: 1, 4


Ich hoffe, ich konnte das Problem halbwegs anschaulich erklären.

vg
Bytecounter
Mitglied: nxclass
23.10.2010 um 22:52 Uhr
typeId 1 die Aufzeichnungen mit folgenden Id's erhalten: 2
typeId 2 die Aufzeichnungen mit folgenden Id's erhalten: 1, 4
Id's - meinst Du die recordId ? - müsste bei typeId 1 dann nicht 1,2,3 das Ergebnis sein ?

Mein erster Ansatz wäre, die Datensätze zu Filtern und in eine temp. Tabelle zu speichern.
01.
CREATE TEMPORARY TABLE `temp_recordType` SELECT * FROM `recordType` WHERE validFrom < CURDATE() OR validFrom is NULL;
Danach könntest Du mit GROUP und der Funktion GROUP_CONCAT() weiter arbeiten. Aber ich glaube ich habe das noch nicht ganz verstanden was Du als Ergebnis haben willst.
Bitte warten ..
Mitglied: bytecounter
25.10.2010 um 08:52 Uhr
Hallo,

hier ein komplettes Beispiel:

record:
id name created
1 Erste Aufzeichnung 2010-10-09
2 Zweiter Aufzeichnung 2010-10-09
3 Dritter Aufzeichnung 2010-10-09
4 Vierter Aufzeichnung Name 2010-10-09
1 Fünfte Aufzeichnung 2010-10-09

recordType siehe oben. Das Ergebnis sollten also allen Spalten aus record sein, deren aktueller RecordType dem Wert X entspricht:
SELECT .... WHERE recordType = 2

Ergebnis:
~record.id record.name record.created recordType.id recordType.typeId
1 Erste Aufzeichnung 2010-10-09 3 2
4 Vierte Aufzeichnung 2010-10-09 9 2

Hoffe, dass es so verständlicher ist.

vg
Bytecounter
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst MYSQL Abfrage Werte summieren (3)

Frage von Ghost108 zum Thema Datenbanken ...

Batch & Shell
gelöst Wie speichere ich von einer "Grundbatchdatei" einen bestimmten Wert? (5)

Frage von IchBins01000010 zum Thema Batch & Shell ...

Batch & Shell
gelöst Powershell Zip extrahieren (2)

Frage von Marabunta zum Thema Batch & Shell ...

Neue Wissensbeiträge
Windows Server

Umstellung SHA 1 auf SHA 2 - Migration der CA von CSP auf KSP

Tipp von Badger zum Thema Windows Server ...

Windows 10

Quato DTP94 unter Windows 10 x64 installieren und verwenden

Anleitung von anteNope zum Thema Windows 10 ...

Windows 10

Win10 1703 und Nutzerkennwörter bei Ersteinrichtung - erstaunliche Erkenntnis

(15)

Erfahrungsbericht von DerWoWusste zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Festplatten, SSD, Raid
gelöst Raid-Controller (Areca) Datenverlust trotz R5 (16)

Frage von sebastian2608 zum Thema Festplatten, SSD, Raid ...

Windows Netzwerk
DNS ins mehreren Subnetzen (11)

Frage von joerg zum Thema Windows Netzwerk ...

Server-Hardware
Starker PC zum Virtualisieren (10)

Frage von canlot zum Thema Server-Hardware ...

Server-Hardware
HP ProLiant DL380 G7, POST Error: 1785-Drive Array not Configured (10)

Frage von Paderman zum Thema Server-Hardware ...