Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Anfängerfragen ›

Datenbankanfrage richtig oder nicht?

Eingetragen von joya (190)
am 27.01.2011 - 14:07 Uhr in
  • Anfängerfragen
  • Drupal 6.x

hallo,
ich habe mir ein Modul gebastelt das mir mehrere Werte aus der Datenbank holt und in einem Block wiedergibt.
Es hat nur mit einer SQL-Anfrage angefangen (Durchschnittswert einer Spalte AVG) aber nach und nach wollte ich auch andere Werte abfragen. (MIN, MAX)
Das Ergebnis ist ein unschöner Code mit einiger SQL-Anfragen hintereinander.

$avg_wert_a= db_result(db_query("SELECT AVG(field_A  FROM tabelle_A WHERE field_b=A));
$avg_min_a= db_result(db_query("SELECT MIN(field_A  FROM tabelle_A WHERE field_b=A));
$avg_max_a= db_result(db_query("SELECT MAX(field_A  FROM tabelle_A WHERE field_b=A));

weiterhin wollte ich Ergebnisse nach einem anderen Parameter B sehen, und dann kamen wieder neue SQL-Sentences dazu

$avg_wert_a= db_result(db_query("SELECT AVG(field_A  FROM tabelle_A WHERE field_b=A));
$avg_min_a= db_result(db_query("SELECT MIN(field_A  FROM tabelle_A WHERE field_b=A));
$avg_max_a= db_result(db_query("SELECT MAX(field_A  FROM tabelle_A WHERE field_b=A));

$avg_wert_b= db_result(db_query("SELECT AVG(field_A  FROM tabelle_A WHERE field_b=B));
$avg_min_b= db_result(db_query("SELECT MIN(field_A  FROM tabelle_A WHERE field_b=B));
$avg_max_b= db_result(db_query("SELECT MAX(field_A  FROM tabelle_A WHERE field_b=B));

Könnte man es anders lösen? (um Verbindungen zur SQL-Datenbank zu sparen)

Ich weiß, das ist kein MySQL-Forum, aber vielleicht könnte mir trotzdem jemand helfen.

Danke

‹ Menü mit Untermenüpunkten extra abbilden Link Kontaktformular im Main Menü platzieren ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

SQL

Eingetragen von stBorchert (6003)
am 27.01.2011 - 14:42 Uhr

Hallo.

joya schrieb

$avg_wert_a= db_result(db_query("SELECT AVG(field_A  FROM tabelle_A WHERE field_b=A));

Das dürfte aufgrund der Klammersetzung so schonmal nicht funktionieren. Du möchtest ja den Durchschnitt von "field_A" und nicht von "field_A FROM tabelle_A ...".

Korrekt ist:

<?php
$avg_wert_a
= db_result(db_query("SELECT AVG(field_A) as avg_value FROM {tabelle_A} WHERE field_b = '%s'", 'A'));
?>

joya schrieb

Könnte man es anders lösen? (um Verbindungen zur SQL-Datenbank zu sparen)

Ungetestet:

<?php
$query_a
= db_query("SELECT AVG(field_A) as avg_value, MIN(field_A) as min_value, MAX(field_A) as max_value FROM {tabelle_A} WHERE field_b = '%s'", 'A');
list(
$avg_wert_a, $min_wert_a, $max_wert_a) = db_fetch_array($query_a);

$query_b = db_query("SELECT AVG(field_A) as avg_value, MIN(field_A) as min_value, MAX(field_A) as max_value FROM {tabelle_A} WHERE field_b = '%s'", 'B');
list(
$avg_wert_b, $min_wert_b, $max_wert_b) = db_fetch_array($query_b);
?>

hth,

 Stefan

  • Anmelden oder Registrieren um Kommentare zu schreiben

ja, das mit Klammern , war

Eingetragen von joya (190)
am 27.01.2011 - 14:46 Uhr

ja, das mit Klammern , war nur eine Anpassung (Vereinfachung) von mir, nur für das Forum. Echte Anfrage ist viel länger, da JOIN und andere Sachen noch drin.

So, danke Dir für deine Antwort, ich denke, ich könnte es gut gebrauchen.

GRuss

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Neuinstallation: vermutlich ein rewrite-Problem
  • Drupal CMS installieren
  • [erledigt]MP3 in Drupal 10 einbinden
  • (gelöst)Drupal 11 installieren
  • Titel ausblenden
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • Rolle erstellen nicht zu finden
  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
Weiter

Neue Kommentare

  • Was für einen Server benutzt
    vor 4 Tagen 19 Stunden
  • Wenn die Subdomain auf
    vor 6 Tagen 17 Stunden
  • ordnerstruktur
    vor 1 Woche 4 Stunden
  • Die Subdomain muß auf den
    vor 1 Woche 2 Tagen
  • Verwende doch das Tag dafür,
    vor 4 Wochen 4 Tagen
  • Guckst du hier: step by step
    vor 4 Wochen 3 Tagen
  • Guckst du hier: step by step
    vor 4 Wochen 3 Tagen
  • Ich habe ja keine Angst vor
    vor 5 Wochen 6 Tagen
  • Ist grundsätzlichmachbar – aber nichts für „einfach mal schnell“
    vor 6 Wochen 1 Tag
  • Vielen Dank erst einmal, aber
    vor 6 Wochen 3 Tagen

Statistik

Beiträge im Forum: 250289
Registrierte User: 20513

Neue User:

  • Scottteday
  • MichaelPeeno
  • Pavlotog

» Alle User anzeigen

User nach Punkten sortiert:
wla9466
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 15 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association