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

Berechnung in MySQL-Query mit mehreren Tabellen

Frage Entwicklung Datenbanken

Mitglied: 58588

58588 (Level 1)

08.12.2007, aktualisiert 16:16 Uhr, 11413 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.

Mit freundlichen Grüßen
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!!!

Mit freundlichen Grüßen
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 ..
Neuester Wissensbeitrag
Internet

Unbemerkt - Telekom Netzumschaltung! - BNG - Broadband Network Gateway

(3)

Erfahrungsbericht von ashnod zum Thema Internet ...

Ähnliche Inhalte
PHP
PHP MySQL Login (7)

Frage von Yanmai zum Thema PHP ...

Webbrowser
gelöst Daten in entfernte Mysql DB schreiben (3)

Frage von nullacht15 zum Thema Webbrowser ...

Heiß diskutierte Inhalte
Windows Server
Outlook Verbindungsversuch mit Exchange (15)

Frage von xbast1x zum Thema Windows Server ...

Grafikkarten & Monitore
Tonprobleme bei Fernseher mit angeschlossenem Laptop über HDMI (11)

Frage von Y3shix zum Thema Grafikkarten & Monitore ...

Microsoft Office
Keine Updates für Office 2016 (11)

Frage von Motte990 zum Thema Microsoft Office ...