Drupal 7: Créer un field datetime dans un schema avec db_create_table

Publicités

Pour la création d’une table dans Drupal7, on peut utiliser le hook « mon_module_update_7000 » dans le fichier « mon_module.install ».

Le type datetime n’est malheureusement pas mapper, c’est pour cela qu’il faut utiliser la clé « mysql_type »

const MON_MODULE_TABLE_NAME = 'mon_module_table'
function get_mon_module_schema() : array {
   return [
      'description' => 'description',
      'fields' => ['id' => ['type' => 'serial', 'unsigned' => TRUE, 'not null' => TRUE],
      'log' => ['type' => 'blob', 'not null' => TRUE],
     'created_at' => [ 'type' => 'datetime', 'mysql_type' => 'datetime', 'not null' => TRUE]
    ],
    'primary key' => ['id']
  ];
}

function mon_module_schema() {
    $schema[API_REST_WATCHDOG_TABLE_NAME] = get_watchdog_schema();
    return $schema;
}

function mon_module_update_7003() {
   if (!db_table_exists(MON_MODULE_TABLE_NAME)) {
      $schema = get_mon_module_schema();
      db_create_table(MON_MODULE_TABLE_NAME, $schema);
   }
}

 

Publicités

Laisser un commentaire