Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Benutzerhandbuch › Entwicklung von Modulen und Themes › Leitfaden zur Entwicklung von Modulen › Erstellen von Modulen für Drupal 6.x ›

.install Dateien schreiben

Eingetragen von stBorchert (6003) am 19.01.2009 - 09:34 Uhr in
  • Drupal 6.x

Dies ist eine Übersetzung der Seite Writing .install files (Drupal 6.x) auf drupal.org.

Eine .install Datei wird bei der Aktivierung eines Moduls das erste Mal aufgerufen und dazu verwendet, die Einrichtung des Moduls vorzunehmen. Die gebräuchlichste Aufgabe ist dabei das Erstellen der Tabellen und Fellder in der Datenbank. Die .install Datei hat keine spezielle Syntax. Sie ist nur eine simple PHP Datei mit anderer Dateiendung.

.install Dateien werden ebenfalls für die Durchführung von Updates verwendet, für den Fall, eine neue Modulversion benötigt dies.

Anweisungen

Installationsanweisungen werden in _install() Funktionen verpackt. Dieser hook wird bei der ersten Aktivierung eines Moduls aufgerufen. Hier können eine beliebige Anzahl an Funktionen implementiert werden, die gebräuchlichste ist jedoch, die vom Modul erforderlichen Tabellen zu erstellen.

Seit Drupal 6.x werden die Tabellen in der Datenbank mittels des Schema API erstellt.
Das Schema API erlaubt den Modulen, ihre Tabellen als ein strukturiertes Array zu deklarieren (ähnlich des Form API). Zusätzlich enthält die API auch Funktionen zum Erstellen, Enfternen und Ändern von Tabellen, Spalten und Indizes.

Beispiel einer Schema-Struktur (aus der Dokumentation des Schema API)

Als Beispiel wird hier ein Ausschnitt der Schemadefinition für die Tabelle 'node' verwendet:

<?php
$schema
['node'] = array(
   
'description' => t('The base table for nodes.'),
   
'fields' => array(
     
'nid' => array(
       
'description' => t('The primary identifier for a node.'),
       
'type' => 'serial',
       
'unsigned' => TRUE,
       
'not null' => TRUE),
     
'vid' => array(
       
'description' => t('The current {node_revisions}.vid version identifier.'),
       
'type' => 'int',
       
'unsigned' => TRUE,
       
'not null' => TRUE,
       
'default' => 0),
     
'type' => array(
       
'description' => t('The {node_type} of this node.'),
       
'type' => 'varchar',
       
'length' => 32,
       
'not null' => TRUE,
       
'default' => ''),
     
'title' => array(
       
'description' => t('The title of this node, always treated a non-markup plain text.'),
       
'type' => 'varchar',
       
'length' => 255,
       
'not null' => TRUE,
       
'default' => ''),
      ),
   
'indexes' => array(
     
'node_changed'        => array('changed'),
     
'node_created'        => array('created'),
      ),
   
'unique keys' => array(
     
'nid_vid' => array('nid', 'vid'),
     
'vid'     => array('vid')
      ),
   
'primary key' => array('nid'),
    );
?>

In diesem Ausschnitt hat die Tabelle 'node' vier Felder (Tabellenspalten) namens 'nid', 'vid', 'type' und 'title'. Jedes Feld spezifiziert seinen Typ (in diesem Beispiel 'serial', 'int' oder 'varchar') und ein paar zusätzliche Parameter (wie z.B. die Beschreibung des Feldes).

Der Primärschlüssel der Tabelle ist das Feld 'nid'. Es gibt weiterhin zwei eindeutige Schlüssel: der Erste heisst 'vid' und beinhaltet nur das Feld 'vid' und der Zweite heisst 'nid_vid', welcher die Felder 'nid' und 'vid' einschliesst. Zwei Indizes ('node_changed' auf dem Feld 'changed' und 'node_created' auf dem Feld 'created') werden ebenfalls angelegt (auch wenn die beiden Felder in diesem Beispiel nicht enthalten sind).

Tabelle erstellen: hook_schema und .install Dateien

Um die Tabellen eines Moduls verwalten zu können, benötigt das Schema API eine Implementierung von hook_schema() in der .install Datei. So kann beispielsweise die Datei mymodule.install diesen Inhalt haben:

<?php
function mymodule_schema() {
 
$schema['mytable1'] = array(
    
// specification for mytable1
 
);
 
$schema['mytable2'] = array(
    
// specification for mytable2
 
);
  return
$schema;
}

function mymodule_install() {
 
// Create my tables.
 
drupal_install_schema('mymodule');
}

function mymodule_uninstall() {
 
// Drop my tables.
 
drupal_uninstall_schema('mymodule');
}
?>

Die Aktualisierung des Schemas für eine neue Modulversion arbeitet so, wie seit Drupal 4.7 bekannt: über hook_update_n(). Angenommen, es soll eine neue Spalte namens 'newcol' zur Tabelle 'mytable1' hinzugefügt werden. Zuerst muss dazu die Schema-Struktur in der Funktion mymodule_schema() angepasst werden, so dass neu erstellt Tabellen (bei der Erstinstallation) die neue Spalte beinhalten. Dann muss eine update Funktion zur Datei mymodule.install hinzugefügt werden:

<?php
function mymodule_update_1() {
 
$ret = array();
 
db_add_field($ret, 'mytable1', 'newcol', array('type' => 'int'));
  return
$ret;
?>

Es gibt auch ein Modul namens Schema Module, das zusätzlich zur den in das Schema API eingebauten Funktionalitäten weitere Funktionen anbietet. Diese erweiterten Funktionen sind für Modulentwickler ziemlich hilfreich. Zur Zeit sind das:

  • Schema Dokumentation: verlinkte Anzeige der im Schema enthaltenen Dokumentation jedes Feldes und jeder Tabelle.
  • Erstellung der Schema-Struktur: das Modul durchsucht die Datenbank und erstellt daraus eine Schema API Datenstruktur.
  • Vergleich von Schemata: das Modul vergleicht die Datenbankstruktur mit der Struktur, die in den aktivierten Modulen angegeben ist. Fehlende oder fehlerhafte Tabellen werden daraufhin aufgelistet.
‹ .info Dateien schreiben nach oben Schreiben von actions (Aktionen) ›
  • 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 Tag 2 Stunden
  • Hey danke
    vor 1 Tag 21 Stunden
  • Update: jetzt gibt's ein
    vor 2 Tagen 15 Stunden
  • Hallo, im Prinzip habe ich
    vor 1 Woche 1 Stunde
  • Da scheint die Terminologie
    vor 1 Woche 4 Stunden
  • Kannst doch auch alles direkt
    vor 1 Woche 4 Tagen
  • In der entsprechenden View
    vor 1 Woche 4 Tagen
  • Dazu müsstest Du vermutlich
    vor 1 Woche 4 Tagen
  • gelöst
    vor 4 Wochen 23 Stunden
  • Ja natürlich. Dass ist etwas,
    vor 4 Wochen 1 Tag

Statistik

Beiträge im Forum: 250233
Registrierte User: 20449

Neue User:

  • Mroppoofpaync
  • 4aficiona2
  • AppBuilder

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

DrupalCenter durchsuchen:

Benutzerhandbuch

  • FAQ - Häufig gestellte Fragen.
  • Links & Downloads
  • Über Drupalcenter.de und das deutschsprachige Benutzerhandbuch
  • Über Drupal
  • Einsteiger
  • Fortgeschrittene
  • Entwicklung von Modulen und Themes
    • Das Drupal Theme System (PHPTemplate)
    • Theme Handbuch (Drupal 6)
    • 5.x Themes in 6.x konvertieren
    • Leitfaden zur Entwicklung von Modulen
      • 5.x
      • Erstellen von Modulen für Drupal 6.x
        • Erstellen von Modulen - ein Handbuch: Drupal 6.x
        • Die Verwendung der Theme-Schicht
        • .info Dateien schreiben
        • .install Dateien schreiben
        • Schreiben von actions (Aktionen)
        • Das Menüsystem von Drupal
      • Verwendung von Icons
    • Module zu Drupal CVS hinzufügen
    • Resourcen für den Theming-Ninja
  • 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