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

  • lstin tombent homophonic wikke
  • Rolle erstellen nicht zu finden
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • 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
Weiter

Neue Kommentare

  • Rollen
    vor 3 Tagen 4 Stunden
  • Inzwischen sind wir bei
    vor 1 Woche 6 Tagen
  • Migrieren von D7 auf D8/ D10/ D11
    vor 2 Wochen 13 Stunden
  • melde mich mal wieder, da ich
    vor 9 Wochen 4 Tagen
  • Hey danke
    vor 9 Wochen 5 Tagen
  • Update: jetzt gibt's ein
    vor 9 Wochen 6 Tagen
  • Hallo, im Prinzip habe ich
    vor 10 Wochen 3 Tagen
  • Da scheint die Terminologie
    vor 10 Wochen 3 Tagen
  • Kannst doch auch alles direkt
    vor 11 Wochen 1 Tag
  • In der entsprechenden View
    vor 11 Wochen 1 Tag

Statistik

Beiträge im Forum: 250238
Registrierte User: 20467

Neue User:

  • StevenEness
  • FoxPiola
  • ocvk2810

» 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 22 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