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, 11609 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
Windows Tools
Managment von mehreren RDP Verbindungen-Terminalserver (9)

Frage von STITDK zum Thema Windows Tools ...

Datenbanken
gelöst MySQL Abfrage für demographische Zwecke (3)

Frage von morphil zum Thema Datenbanken ...

Datenbanken
gelöst MSSQL-Benutzer . Zugriff nur auf 2 Tabellen und 1 View (3)

Frage von Snuffchen zum Thema Datenbanken ...

Neue Wissensbeiträge
Tipps & Tricks

Wie Hackt man sich am besten in ein Computernetzwerk ein

(29)

Erfahrungsbericht von Herbrich19 zum Thema Tipps & Tricks ...

Humor (lol)

Bester Vorschlag eines Supporttechnikers ever: APC

(15)

Erfahrungsbericht von DerWoWusste zum Thema Humor (lol) ...

Windows Server

Exchange 2010 Active Directory und Windows Server 2016

(4)

Erfahrungsbericht von Herbrich19 zum Thema Windows Server ...

Heiß diskutierte Inhalte
Internet
gelöst Mitarbeiter surft auf unerwünschter Seite - Wie damit umgehen? (50)

Frage von sabines zum Thema Internet ...

Router & Routing
PFsense - Netzverbindung steht, aber kein Internet vorhanden (24)

Frage von aschmid zum Thema Router & Routing ...

Windows Server
Windows 2016 Hyper-V und VHDS (15)

Frage von emeriks zum Thema Windows Server ...

LAN, WAN, Wireless
gelöst Eintägige Netzwerkunterbrechung trotz Backupleitung (15)

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