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

  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • 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
  • 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
Weiter

Neue Kommentare

  • Arrrrg. Nix Tabelle :-D /*
    vor 16 Stunden 42 Minuten
  • Textboxen mit Tabelle
    vor 23 Stunden 21 Minuten
  • Du sollst ja auch keine
    vor 23 Stunden 33 Minuten
  • Theme
    vor 1 Tag 8 Minuten
  • Welches Theme benutzt du
    vor 1 Tag 5 Stunden
  • Mit Responsive Raster hatte
    vor 1 Tag 19 Stunden
  • Hallo Alex,um das Häkchen
    vor 2 Tagen 4 Stunden
  • Modul view_unpublished
    vor 3 Tagen 7 Stunden
  • Modul "override node options"
    vor 4 Tagen 2 Stunden
  • Im Grunde ist dass ein
    vor 6 Tagen 7 Stunden

Statistik

Beiträge im Forum: 250270
Registrierte User: 20476

Neue User:

  • AltonRaf
  • JeffreyPaf
  • StevenEness

» Alle User anzeigen

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