Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Benutzerhandbuch › Fortgeschrittene › Tutorials & How To's - Tipps & Tricks › Kurztipps - Dinge die Stunden sparen können. ›

Kurztutorial - MySQL JOINs mit Drupal

Eingetragen von derjochenmeyer@... (591) am 27.12.2007 - 00:33 Uhr

Wer komplizierte Datenbank Abfragen braucht, kommt mit views ganz schön weit. Wenn die Daten zu einem node über viele Tabellen verteilt sind und es keine Views-Integration gibt, was dann?

Man kann JOINs nutzen. Das kann in einigen Fällen auch zu schnelleren Abfragen führen. Hie ein Beispiel:

<?php

$query
= db_query(db_rewrite_sql("SELECT
n.nid,
n.title,
n.sticky,
term_data.tid,
term_data.name,
term_data.weight,
term_hierarchy.parent,
content_type_deinTyp.field_deinFeld_fid,
files.filename,
files.filepath,
FROM {node} n
INNER JOIN content_type_deinTyp ON content_type_deinTyp.nid = n.nid
LEFT JOIN files ON content_type_deinTyp.field_deinFeld_fid = files.fid
INNER JOIN term_node ON term_node.nid = n.nid
LEFT JOIN term_data ON term_node.tid = term_data.tid
LEFT JOIN term_hierarchy ON term_hierarchy.tid = term_data.tid
WHERE n.type = 'deinTyp' AND term_data.vid = 9
ORDER BY term_hierarchy.parent, term_data.weight, term_data.name, n.sticky DESC, n.title"
));

while (
$nodes = db_fetch_object($query)) {
 
// Daten verwenden
}

?>

Verwirrt? Also Schritt für Schritt:

  • wir packen die ganze Abfrage wie gehabt in die beiden Drupal Funktionen db_query() und db_rewrite_sql() (dazu auch hier:http://www.drupalcenter.de/handbuch/6722).
  • Nach SELECT folgen alle felder die abgefragt werden sollen nach folgendem schema: tabellenname.feldname (also: n.nid, n.title, n.sticky, term_data.tid, usw.) Wenn man alles aus einer tabelle braucht geht auch tabellenname.*
  • Danach, also hinter FROM, wird angegeben wie die Tabellen verknüpft werden sollen (JOIN)
  • FROM {node} n ist die Haupttabelle sozusagen (die am weitesten links in der Abfrage steht!) -> eine Besonderheit noch: dem tabellenname {node} wird das Kürzel "n" gegeben. Damit kann man node.nid auch mit n.nid ansprechen.
  • und jetzt die JOINS. "INNER JOIN content_type_deinTyp ON content_type_deinTyp.nid = n.nid" bedeutet, dass die Tabellen content_type_deinTyp und node verknüpft werden sollen. Und zwar überall da, wo NodeID (nid) in node (n.nid) und in content_type_deinTyp (content_type_deinTyp.nid) gleich sind => "ON content_type_deinTyp.nid = n.nid"
  • So, das wars schon fast. Jetzt sollte man noch erwähnen, dass INNER JOIN bedeutet, dass nur Einträge bei der Abfrage rauskommen, die in beiden Tabellen übereinstimmende Werte in den gewünschten Feldern haben (hier die NodeID).
  • LEFT JOIN hingegen heisst, dass die Werte der linken Tabelle auf jeden Fall bei der Abfrage rauskommen und immer wenn vorhanden mit den Zeilen der Rechten Tabelle verknüpft werden. LEFT JOIN files ON content_type_deinTyp.field_deinFeld_fid = files.fid

Das nochmal weniger wortreich:

  • SELECT n.nid, usw. listet alle gewünschten Felder
  • FROM {node} n nennt die Haupttabelle
  • INNER JOIN content_type_deinTyp ON content_type_deinTyp.nid = n.nid verknüpft die node Tablle mit der zugehörigen CCK Tablle, und zwar nur da, wo in beiden Tabellen Werte vorhanden sind.
  • LEFT JOIN files ON content_type_deinTyp.field_deinBild_fid = files.fid sucht wenn vorhanden zugehörige Bilder
  • INNER JOIN term_node ON term_node.nid = n.nid sucht zugehörige Taxonomy-Terms (in der Tabelle stehen nur Zahlen)
  • LEFT JOIN term_data ON term_node.tid = term_data.tid holt die zugehörigen Term-Namen
  • LEFT JOIN term_hierarchy ON term_hierarchy.tid = term_data.tid holt zugehörige übergeordnete Terms
  • WHERE n.type = 'deinTyp' AND term_data.vid = 9 nur vom Typ "deinTyp" und wo es Terms aus Vokabular 9 gibt
  • ORDER BY term_hierarchy.parent, term_data.weight, term_data.name, n.sticky DESC, n.title" und noch vorsortieren, erst nach übergeordnetem Taxonomy-Term, dann nach Term-Gewichtung, dann Terms alphabetisch, dann erst die sticky nodes, und dann alphabetisch nach node Name.

Voll easy oder? ;) Wenn ichs wieder vergessen hab, kann ich ja hier nachschauen. Vieleicht hilfts jemandem.

‹ Korrekte Sprachversion auf Startseite mit i18n nach oben Kurztutorial - richtig SQL mit Drupal ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Held ;-)

Eingetragen von glueckskind (120)
am 25.02.2008 - 18:47 Uhr

Held ;-)

  • Anmelden oder Registrieren um Kommentare zu schreiben

Tolle Erklärung

Eingetragen von grandcat (83)
am 18.09.2008 - 20:52 Uhr

Tolle Erklärung =D

-------------------------------------
Meine Entwicklungen:

www.minis-kuemmersbruck.de | www.hausmeisterteam-glaser.de

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

Statistik

Beiträge im Forum: 250238
Registrierte User: 20466

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 18 Gäste online.

DrupalCenter durchsuchen:

Benutzerhandbuch

  • FAQ - Häufig gestellte Fragen.
  • Links & Downloads
  • Über Drupalcenter.de und das deutschsprachige Benutzerhandbuch
  • Über Drupal
  • Einsteiger
  • Fortgeschrittene
    • Best Practice - Drupal Sites - Guidelines
    • Die beliebtesten Themes und Module
    • Tutorials & How To's - Tipps & Tricks
      • Kurztipps - Dinge die Stunden sparen können.
        • (nachträgliche) Multisite-Installation
        • Anmeldename im Titel von selbst erstellten Blocks (oder Menüs)
        • Bedingt Seiten von Suchmachinen ausschliessen
        • Block Titel ausblenden
        • CHMOD im files bzw. Dokumentenverzeichnis mit PHP wenn Verzeichnisse von Drupal automatisch angelegt wurden und man nicht der Eigentümer ist und sie per FTP nicht löschen darf
        • CSS
        • Debugging Tools
        • Devel Modul installieren
        • E-Mail-Einstellungen für Benutzer - mehrsprachig.
        • Eigenes Template für die Sprachauswahl
        • Inhalt collapsibel darstellen
        • Korrekte Sprachversion auf Startseite mit i18n
        • Kurztutorial - MySQL JOINs mit Drupal
        • Kurztutorial - richtig SQL mit Drupal
        • Maximale Dateigröße für Uploads (Dateianhänge usw) vergrössern
        • MySQL: Referenz auf Tabelle trotz Präfix
        • Sidebar "ausblenden"
        • custom Search auf Drupal.org für Firefox
        • embedded views (mit Argumenten direkt in einer .tpl.php)
        • externe Daten als nodes importieren
        • print_r($node)
      • Notfallpläne - Tipps die Deine Drupalinstallation retten können
      • Anleitung zur Erstellung eines einfachen Kontaktformulars
      • Arbeiten mit dem Drupal Taxonomie-System [beinhaltet veraltete Inhalte]
      • Bearbeiten-Tab zu jeden Block hinzufügen
      • Block View mit Argument
      • Das Tagebuch einer Site
      • Drupal 6 - Automatisch unterschiedliche Bildgröße bei Teaser und Artikel
      • Drupal 6 - Eigene CSS Datei in ein Theme integrieren
      • Drupal 6 - Einfache Bildergalerie mit Image und Lightbox2
      • Drupal 6 - Einrichten eines Kalenders
      • Drupal 6 - Google Adsense ohne Zusatzmodul einbinden
      • Drupal 6 - Hauptnavigation mit DropDown Effekt ab Ebene Zwei
      • Drupal 6 - ImageMagick mit XAMPP Lite nutzen
      • Drupal 6 - Imagefield mit Imagecache und Colorbox
      • Drupal 6 - Installation FCK Editor
      • Drupal 6 - Installieren der WYSIWYG API inkl. Editoren
      • Drupal 7: mehrere Bilder in Node: 1 Bild in Anrisstext
      • Drupal Code Highlighting in Redmine Projektarchiv (CodeRay)
      • Drupal Theming: JavaScript einhängen in Abhängigkeit von Page-Variablen
      • Drush - Das Schweizermesser für Drupal auf Kommandozeile
      • Einfaches und erfolgreiches Patchen unter Windows
      • Eingabeformat & Inputfilter
      • Einrichten eines einfachen, statischen Menüsystems
      • Erstellen von Patches
      • Gallery mit CCK und Views erstellen (Drupal 5)
      • Header image Modul einrichten
      • Inhaltsübersicht für einen User mit einem View erstellen
      • Javascript und CSS-Dateien einbinden
      • Kontaktformular mit Jquery aufwerten
      • Leitfaden zur Erstellung von Suchmaschinenoptimierten Drupal-Sites
      • Mac OSX - Backupskript für Websites auf MAMP
      • Module updaten via Shell auf Windows
      • Module übersetzen
      • Perl-Script zum Erzeugen einer statischen Kopie einer Drupal-Website
      • Portierung eine Themes von openwebdesign.org
      • Prozentbalken bei Views (Balkendiagramm)
      • Themen eines Node-Formulars
      • Titel mit Stil
      • Umkreissuche mit Location- und Views-Modul
      • Usergalerie mit ImageCache, CCK, Views + Thickbox
      • Userprofil mit Usernodes erstellen
      • Validierung von Usereingaben bei Nodes
      • Variation vom Showroom auf drupalcenter.de
      • View mit Eingabeformular für neue Beiträge
      • WebSVN mit Drupal Code Highlighting
      • Zusätzliche Submit-Schaltfläche in Node-Formularen
      • i18n Language Switcher Block, die Links mit den Flaggen themen
      • ui.slider als Ersatz für den Ajax-Pager von Views
      • Zugriffsbeschränkungen für Nodes - eine Übersicht der Möglichkeiten
  • Entwicklung von Modulen und Themes
  • Drupalcenters Community
  • Drupal 7 Video-Trainings (Deutsch)
  • Drupal-Testumgebung erstellen
  • Drupal 6 Module
  • Drupal 7 Module
  • Drupal Screencasts auf deutsch
  • Archiv

Das Copyright des deutschsprachigen Drupal-Benutzerhandbuches unterliegt den jeweiligen Autoren. Übersetzungen des englischsprachigen Drupal-Benutzerhandbuches unterliegen der Creative Commons License, Attribution-ShareAlike 2.0.

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