Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Anfängerfragen ›

[gelöst]meinmodul.install erstellt keine Tabelle...finde den Fehler nicht

Eingetragen von Ati (210)
am 01.03.2011 - 12:25 Uhr in
  • Anfängerfragen
  • Drupal 6.x

Hallo zusammen,

gemäß einem Tutorial, sowie diesem Link habe ich mal versucht per meinmodul.install
eine entsprechende Tabelle in der DB zu erstellen. Wenn ich jetzt bei meinem Modul den Haken setze und speichere kommt die angehängt Fehlermeldung.
Aber ich finde den Fehler nicht. Könnt ihr mir helfen? Hier mal meine komplette install-Datei:

<?php

function lsrouting_schema() {
  $schema['lsrouting'] = array(
    'fields' => array(
      'ls_id' => array(
        'type' => 'int',
        'unsigned' => TRUE,
        'auto_increment' => TRUE,
        'not null' => TRUE,
        'size' => 6),
      'tour' => array(
        'type' => 'text',
        'not null' => TRUE,
        'size' => 25 ), 
      'au' => array(
        'type' => 'text',
        'not null' => TRUE,
        'size' => 25), 
      'dat' => array(
        'type' => 'datetime',
        'not null' => TRUE,
        'default' => 0 ), 
    ),
    'primary key' => array('ls_id'),
  );
  return $schema;
  }

function lsrouting_install(){
  drupal_install_schema('lsrouting');
  }
 
function lsrouting_uninstall(){
  drupal_uninstall_schema('lsrouting');
  }
 

Das abschliessende "?>" habe ich weggelassen da ich ansonsten nach dem speichern nur eine weiße Seite angezeigt bekomme:

AnhangGröße
drupal5.jpg46.03 KB
‹ Drupal Homepage erstellen Wie sollte man mit Description umgehen? ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Probier mal

Eingetragen von Sense (1560)
am 01.03.2011 - 13:18 Uhr

Probier mal folgendes:

<?php
function lsrouting_schema() {
 
$schema['lsrouting'] = array(
   
'fields' => array(
     
'ls_id' => array(
       
'type' => 'serial',
       
'unsigned' => TRUE,
       
'not null' => TRUE,
      ),
     
'tour' => array(
       
'type' => 'text',
       
'not null' => TRUE,
       
'size' => 'big',
      ),
     
'au' => array(
       
'type' => 'text',
       
'not null' => TRUE,
       
'size' => 'big',
      ),
     
'dat' => array(
       
'type' => 'datetime',
      ),
    ),
   
'primary key' => array('ls_id'),
  );

  return
$schema;
}

function
lsrouting_install(){
 
drupal_install_schema('lsrouting');
}

function
lsrouting_uninstall(){
 
drupal_uninstall_schema('lsrouting');
}
?>

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hm das hat jetzt

Eingetragen von Ati (210)
am 01.03.2011 - 13:35 Uhr

Hm das hat jetzt funktioniert...kannst Du mir dieses Phänomen auch erklären??

  • Anmelden oder Registrieren um Kommentare zu schreiben

Du hast die Datentypen der

Eingetragen von Exterior (2903)
am 01.03.2011 - 15:43 Uhr

Du hast die Datentypen der Tabellen falsch verwendet. Sowas wie "'type' => 'int', 'auto_increment' => TRUE" gibt es z. B. so nicht, dafür wird 'type' => 'serial' verwendet. Außerdem waren deine Size-Angaben falsch usw.

Siehe hier:

http://drupal.org/node/159605

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ahh okay gemerkt!

Eingetragen von Ati (210)
am 01.03.2011 - 16:23 Uhr

Ahh okay gemerkt!

  • Anmelden oder Registrieren um Kommentare zu schreiben

Entschuldigt das ich mich

Eingetragen von notnamed (56)
am 22.03.2012 - 10:42 Uhr

Entschuldigt das ich mich hier einfach anhänge, aber wie erstelle ich den bei einem install mehere tabellen und wie spreche ich diese später an?
Danke euch!

  • Anmelden oder Registrieren um Kommentare zu schreiben

im hook_install definierst Du

Eingetragen von Sense (1560)
am 22.03.2012 - 11:01 Uhr

im hook_install definierst Du dir einfach ein weiteres Schema, dann wird dieses ebenso angelegt.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Danke für die Hilfe! Leider

Eingetragen von notnamed (56)
am 22.03.2012 - 11:18 Uhr

Danke für die Hilfe!

Leider erstellt er bei mir nicht die Tabelle groups...
Kannst du mir helfen?

<?php

<?php

/**
* @file
* The inactive user module controls inactive users.
*
* The inactive user module sends mails to inactive users.
* The user can configure the time after Drupal sends mails.
*/

/**
* Implements hook_schema().
*/
function inactive_user_schema() {
 
$schema['inactive_user_groups'] = array(
   
'description' => 'The table for groups how to check by inactive_users.',
   
'fields' => array(
        
'uid' => array(
         
'description' => 'The primary identifier for a usergroup.',
         
'type' => 'int',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
    ),
   
'primary key' => array('uid'),
   );
 
$schema['inactive_users'] = array(
   
'description' => 'The base table for inactive_users.',
     
'fields' => array(
       
'uid' => array(
         
'description' => 'The primary identifier for a user.',
         
'type' => 'int',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'notified_admin' => array(
         
'description' => 'Admin notifier.',
         
'type' => 'int',
         
'size' => 'tiny',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'notified_user' => array(
         
'description' => 'User notifier.',
         
'type' => 'int',
         
'size' => 'tiny',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'warned_user_block_timestamp' => array(
         
'description' => 'Timestamp warning.',
         
'type' => 'int',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'notified_user_block' => array(
         
'description' => 'User block warning.',
         
'type' => 'int',
         
'size' => 'tiny',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'notified_admin_block' => array(
         
'description' => 'Timestamp warning.',
         
'type' => 'int',
         
'size' => 'tiny',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'warned_user_delete_timestamp' => array(
         
'description' => 'Timestamp warning.',
         
'type' => 'int',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
       
'protected' => array(
         
'description' => 'Timestamp warning.',
         
'type' => 'int',
         
'size' => 'tiny',
         
'unsigned' => TRUE,
         
'not null' => TRUE,
         
'default' => 0),
      ),
     
'primary key' => array('uid'),
    );
  return
$schema;
}

/**
* Implements hook_uninstall().
*/
function inactive_user_uninstall() {
 
//SELECT name FROM variable WHERE (name LIKE 'inactive_user_%');
 
$query = db_select('variable', 'v')
  ->
fields('v', array('name'))
  ->
condition('name', 'inactive_user_%', 'LIKE')
  ->
execute()
  ->
fetchAll();

  foreach (
$query as $row) {
   
variable_del($row->name);
  }
 
drupal_set_message(t('Inactive user has been uninstalled.'));
}


?>

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hattest du das Modul schonmal

Eingetragen von Exterior (2903)
am 22.03.2012 - 11:55 Uhr

Hattest du das Modul schonmal aktiviert und danach erst die Tabelle ins Schema aufgenommen und versucht, das Modul neu zu aktivieren?

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ja es war schon mal aktiv,

Eingetragen von notnamed (56)
am 22.03.2012 - 12:30 Uhr

Ja es war schon mal aktiv, dann deaktiviert und wieder aktiviert.
Ist in phpMyAdmin aber nicht zu finden :-(

  • Anmelden oder Registrieren um Kommentare zu schreiben

Die Installroutine wird nur

Eingetragen von wla (9466)
am 22.03.2012 - 12:44 Uhr

Die Installroutine wird nur beim ersten Aktivieren durchlaufen. Also deaktivieren, deinstallieren und dann wieder aktivieren, damit der hook_install mit der Schema-Definition greift.

Beste Grüße
Werner

  • Anmelden oder Registrieren um Kommentare zu schreiben

Oder einfach hook_update_N

Eingetragen von Exterior (2903)
am 22.03.2012 - 12:47 Uhr

Oder einfach hook_update_N verwenden.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Danke hat funktioniert! Jetzt

Eingetragen von notnamed (56)
am 22.03.2012 - 14:29 Uhr

Danke hat funktioniert!
Jetzt zum nächsten problem http://www.drupalcenter.de/node/40593#comment-145145
;-)

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Neuinstallation: vermutlich ein rewrite-Problem
  • Drupal CMS installieren
  • [erledigt]MP3 in Drupal 10 einbinden
  • (gelöst)Drupal 11 installieren
  • Titel ausblenden
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • 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
Weiter

Neue Kommentare

  • Was für einen Server benutzt
    vor 3 Tagen 11 Stunden
  • Wenn die Subdomain auf
    vor 5 Tagen 10 Stunden
  • ordnerstruktur
    vor 5 Tagen 20 Stunden
  • Die Subdomain muß auf den
    vor 1 Woche 1 Tag
  • Verwende doch das Tag dafür,
    vor 4 Wochen 3 Tagen
  • Guckst du hier: step by step
    vor 4 Wochen 2 Tagen
  • Guckst du hier: step by step
    vor 4 Wochen 2 Tagen
  • Ich habe ja keine Angst vor
    vor 5 Wochen 5 Tagen
  • Ist grundsätzlichmachbar – aber nichts für „einfach mal schnell“
    vor 6 Wochen 7 Stunden
  • Vielen Dank erst einmal, aber
    vor 6 Wochen 2 Tagen

Statistik

Beiträge im Forum: 250289
Registrierte User: 20513

Neue User:

  • Scottteday
  • MichaelPeeno
  • Pavlotog

» Alle User anzeigen

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