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 - 13: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 - 13: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 - 13: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

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 1 Woche 6 Tagen
  • Hey danke
    vor 2 Wochen 57 Sekunden
  • Update: jetzt gibt's ein
    vor 2 Wochen 18 Stunden
  • Hallo, im Prinzip habe ich
    vor 2 Wochen 5 Tagen
  • Da scheint die Terminologie
    vor 2 Wochen 5 Tagen
  • Kannst doch auch alles direkt
    vor 3 Wochen 2 Tagen
  • In der entsprechenden View
    vor 3 Wochen 2 Tagen
  • Dazu müsstest Du vermutlich
    vor 3 Wochen 2 Tagen
  • gelöst
    vor 5 Wochen 6 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 6 Wochen 19 Minuten

Statistik

Beiträge im Forum: 250233
Registrierte User: 20451

Neue User:

  • ByteScrapers
  • Mroppoofpaync
  • 4aficiona2

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 33 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