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

Berechnung in MySQL-Query mit mehreren Tabellen

Mitglied: 58588

58588 (Level 1)

08.12.2007, aktualisiert 16:16 Uhr, 12023 Aufrufe, 3 Kommentare

Berechnung mit Werten aus verschiedenen Tabellen inerhalb des Querys

Hallo, also ich habe ein Problem mit einer MySQL Datenbankabfrage in PHP. Ich möchte alle Datensätze anzeigen
bei denen die Summe zweier Werte kleiner ist als die Userwerte. Die Informationen zu dem datensatz stehen
in einer Tabelle 'daten', die zu addierenden Zahlen stehen in einer anderen tabelle, welche mit der datentabelle verknüpft ist.
Die werte des Users der die Abfrage, sagen wir beispielsweise per Buttonklick auslöst stehen in der 'user' Tabelle.

Mein Aufbau:

Tabelle 'daten':

daten_id
werte_id
daten_beschreibung

Tabelle 'werte':

werte_id
daten_id
wert_01
wert_02

Tabelle 'user':

user_id
userwert_01
userwert_02


Meine Abfrage sollte irgendwie folgendes tun:
Gib mir alle Daten aus der Tabelle 'daten' bei denen Wert_01 + wert_02 kleiner ist als userwert_01 + userwert_02
Das einzige was ich als variable habe ist die user_id.

So mein Problem ist schonmal, wie spreche ich mehrer Tabellen gleichzeitig an?
Kann ich in einem SQL Query auch schon mit den Werten rechnen oder sollte ich einfach alle Werte auslesen und danach selektieren?
Was ist schneller, ein langer Query oder einen Berechnung in PHP?

So, mein Problem hab ich etwas vereinfacht, meine Berechnung sieht wesentlich komplexer aus, aber dann steigt man nicht gleich durch
und ich möchte ja auch das mir jemand hilft und nicht gleich schreiend davon rennt.

mfg
tobi
Mitglied: creyzee
08.12.2007 um 08:54 Uhr
guten morgen,

ich glaube, da fehlen noch ein paar angaben. welche datentypen haben die felder der tabellen? gibt es primärschlüssel?

ich geh mal von folgendem aus:

tabelle 'daten'
daten_id .. long .. primärschl.
werte_id .. long .. primärschl.
daten_beschreibung .. text

tabelle 'werte'
daten_id .. long .. primärschl.
werte_id .. long .. primärschl.
wert_01 .. long
wert_02 .. long

tabelle 'user'
user_id .. long .. primärschl.
userwert_01 .. long
userwert_02 .. long

und die tabellen 'werte' und 'daten' sind verknüpft? also bestimmt über 'daten_id' und 'werte_id'

dann könnte die sql-abfrage wie folgt lauten:

"SELECT daten.* FROM [user], daten INNER JOIN werte ON (daten.werte_id = werte.werte_id) AND (daten.daten_id = werte.daten_id) WHERE ((([wert_01]+[wert_02])<([user_01]+[user_02])));"

wobei hier folgendes problem auftritt: die werte 'user_01' und 'user_02' kommen aus der tabelle 'user'. dort stehen bestimmt mehrere werte drin. die abfrage soll aber bestimmt nur für einen user ausgeführt werden, oder? wenn das der fall ist, solltes du die berechnung des terms '([user_01]+[user_02])' unter php ausführen. es gibt nämlich keine beziehung zwischen den tabellen 'daten'/'werte' und 'user'. Das könnte dann so aussehen:

"SELECT daten.* FROM daten INNER JOIN werte ON (daten.werte_id = werte.werte_id) AND (daten.daten_id = werte.daten_id) WHERE ((([wert_01]+[wert_02])<" & (user_01+user_02) & "));"

ich kenne zwar die genaue syntax unter php nicht, aber so würde das sql-statement aussehen.

bis denne, der creyzee
Bitte warten ..
Mitglied: 58588
08.12.2007 um 10:36 Uhr
WOW, also ich bin begeistert, wie schnell man hier eine fachlich kompetente Antwort erhält!!! In anderen Foren wird erstmal darüber abgestimmt ob man nur zu dumm ist und ober man einer Antwort würdig ist. Wirklich Cool!!!

Vielen Dank creyzee. INNER JOIN werde ich mir wohl im MySQL Handbuch mal genauer anschaun, werde es heute gleich mal testen!!!

mfg
Tobi
Bitte warten ..
Mitglied: creyzee
08.12.2007 um 16:16 Uhr
hallo,

ist doch kein thema. sag bescheid, ob es so klappt bzw wenn du noch was brauchst.

der creyzee
Bitte warten ..
Ähnliche Inhalte
Datenbanken

Inkonsistente MySQL Tabellen wiederherstellen

Frage von AndroxinDatenbanken1 Kommentar

Moin, aus "Gründen" musste ich diverse MySQL Datenbanken von einer formatierten Festplatte wiederherstellen. In der Regel waren auch noch ...

Datenbanken

MySQL zwei Tabellen zusammenführen

gelöst Frage von RedBullmachtfitDatenbanken10 Kommentare

Hallo, ich habe in MySQL eine Artikel-Tabelle in welcher alle Artikel gespeichert sind sowie eine art_preise-Tabelle, in welcher nur ...

Datenbanken

MySQL - Feld aus anderer Tabelle hinzusummieren?

gelöst Frage von 1410640014Datenbanken5 Kommentare

Hallo, habe ein banales Problem und bin leider mit JOINS nicht gut bewandert. zwei simple Lagertabellen mit den Felder: ...

Datenbanken

Mysql Select Befehl über 3 Tabellen?

gelöst Frage von rdklieDatenbanken6 Kommentare

Guten Tag zusammen! Ich habe eine kleine Frage bezüglich Mysql. Zur Fragestellung: Die Frage wäre "Welche Mitglieder organisieren Veranstaltungen ...

Neue Wissensbeiträge
Windows Netzwerk

CGM Praxisarchiv funktioniert auf Clients nach Update auf 4.14 nicht mehr

Tipp von MOS6581 vor 16 StundenWindows Netzwerk

Moin, ein Kunde setzt das CGM-Praxisarchiv ein. Mehrplatzinstallation mit SQL-Server. Nachdem letzte Woche auf die 4.14 aktualisiert wurde, funktionierte ...

Windows 10

Win 10 - Storage Sense - neues herstellerseitiges Cleaning-Tool statt cleanmgr

Tipp von mathu vor 23 StundenWindows 102 Kommentare

Vermutlich ab dem Oktoberrelease wird eine neue Speicherbereinigungssuftware ausgeliefert von Microsoft. Cleanmgr.exe soll angeblich aber noch weiter parallel verfügbar ...

E-Mail
Neueste Masche der Bad Guys: Offene Erpressung
Information von the-buccaneer vor 1 TagE-Mail15 Kommentare

"Warum den komplizierten Weg über einen Kryptotrojaner nehmen, wenn man die Leute auch direkt erpressen kann?" haben sich wohl ...

Viren und Trojaner
Neues ct-desinfect 2018 erschienen
Information von Lochkartenstanzer vor 2 TagenViren und Trojaner1 Kommentar

Moin, heise hat eine neues Sonderheft Desinfect veröffentlicht (9,90€/12,90€) . Falls jemand öfter mal Kisten "säubern" muß ist das ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
Kombiniere mehrere 4G Router zu einem Netzwerk - Anwendung kleine LAN (10-20 Leute)
Frage von HulkTheHeroLAN, WAN, Wireless24 Kommentare

Guten Mittag liebes Administrator - Fourm, ich hoffe ich habe das richtige Thema ausgewählt - ansonsten bitte gerne verschieben ...

Windows Server
Fileserver von 2012 R2 auf 2012R2
gelöst Frage von ThabeusWindows Server23 Kommentare

Moin moin, leider war in der Vergangenheit der Fokus des Betriebs nicht auf Langfristigkeit ausgelegt. Daher stehe ich jetzt ...

Windows Server
2012 R2 Server Keine Anmeldung möglich Meldung: Laut den Sicherheitsrichtlinien auf diesem PC sollen informationen zur letzten interaktiven Anmeldung angezeigt werden
Frage von Speedy18A4Windows Server21 Kommentare

Hallo, ich habe vor einigen Wochen einen zweiten Domain Controller zu meiner Domain hinzugefügt. Funktionierte alles wunderbar. Auch die ...

Hyper-V
Windows Serer 2016 Standard virtualisieren
gelöst Frage von fritte87Hyper-V18 Kommentare

Hallo zusammen, ich muss für eine kleine Firma ein entsprechendes neues kleines Konzept bauen. Ich habe einen Server Standard ...