[gelöst]meinmodul.install erstellt keine Tabelle...finde den Fehler nicht
am 01.03.2011 - 11:25 Uhr in
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:
| Anhang | Größe |
|---|---|
| drupal5.jpg | 46.03 KB |
- Anmelden oder Registrieren um Kommentare zu schreiben

Probier mal
am 01.03.2011 - 12: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');
}
?>
Hm das hat jetzt
am 01.03.2011 - 12:35 Uhr
Hm das hat jetzt funktioniert...kannst Du mir dieses Phänomen auch erklären??
Du hast die Datentypen der
am 01.03.2011 - 14: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
Ahh okay gemerkt!
am 01.03.2011 - 15:23 Uhr
Ahh okay gemerkt!
Entschuldigt das ich mich
am 22.03.2012 - 09: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!
im hook_install definierst Du
am 22.03.2012 - 10:01 Uhr
im hook_install definierst Du dir einfach ein weiteres Schema, dann wird dieses ebenso angelegt.
Danke für die Hilfe! Leider
am 22.03.2012 - 10: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.'));
}
?>
Hattest du das Modul schonmal
am 22.03.2012 - 10:55 Uhr
Hattest du das Modul schonmal aktiviert und danach erst die Tabelle ins Schema aufgenommen und versucht, das Modul neu zu aktivieren?
Ja es war schon mal aktiv,
am 22.03.2012 - 11:30 Uhr
Ja es war schon mal aktiv, dann deaktiviert und wieder aktiviert.
Ist in phpMyAdmin aber nicht zu finden :-(
Die Installroutine wird nur
am 22.03.2012 - 11: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
Oder einfach hook_update_N
am 22.03.2012 - 11:47 Uhr
Oder einfach hook_update_N verwenden.
Danke hat funktioniert! Jetzt
am 22.03.2012 - 13:29 Uhr
Danke hat funktioniert!
Jetzt zum nächsten problem http://www.drupalcenter.de/node/40593#comment-145145
;-)