function Schema::createTableSql
Generate SQL to create a new table from a Drupal schema definition.
This method should be implemented in extending classes.
@todo This method is called by Schema::createTable on the abstract class, and therefore should be defined as well on the abstract class to prevent static analysis errors. In D11, consider changing it to an abstract method, or to make it private for each driver, and ::createTable actually an abstract method here for implementation in each driver.
Parameters
string $name: The name of the table to create.
array $table: A Schema API table definition array.
Return value
array An array of SQL statements to create the table.
Overrides Schema::createTableSql
File
- 
              core/modules/ pgsql/ src/ Driver/ Database/ pgsql/ Schema.php, line 286 
Class
- Schema
- PostgreSQL implementation of \Drupal\Core\Database\Schema.
Namespace
Drupal\pgsql\Driver\Database\pgsqlCode
protected function createTableSql($name, $table) {
  $sql_fields = [];
  foreach ($table['fields'] as $field_name => $field) {
    $sql_fields[] = $this->createFieldSql($field_name, $this->processField($field));
  }
  $sql_keys = [];
  if (!empty($table['primary key']) && is_array($table['primary key'])) {
    $this->ensureNotNullPrimaryKey($table['primary key'], $table['fields']);
    $sql_keys[] = 'CONSTRAINT ' . $this->ensureIdentifiersLength($name, '', 'pkey') . ' PRIMARY KEY (' . $this->createPrimaryKeySql($table['primary key']) . ')';
  }
  if (isset($table['unique keys']) && is_array($table['unique keys'])) {
    foreach ($table['unique keys'] as $key_name => $key) {
      // Use the createPrimaryKeySql(), which already discards any prefix
      // lengths passed as part of the key column specifiers. (Postgres
      // doesn't support setting a prefix length for PRIMARY or UNIQUE
      // indices.)
      $sql_keys[] = 'CONSTRAINT ' . $this->ensureIdentifiersLength($name, $key_name, 'key') . ' UNIQUE (' . $this->createPrimaryKeySql($key) . ')';
    }
  }
  $sql = "CREATE TABLE {" . $name . "} (\n\t";
  $sql .= implode(",\n\t", $sql_fields);
  if (count($sql_keys) > 0) {
    $sql .= ",\n\t";
  }
  $sql .= implode(",\n\t", $sql_keys);
  $sql .= "\n)";
  $statements[] = $sql;
  if (isset($table['indexes']) && is_array($table['indexes'])) {
    foreach ($table['indexes'] as $key_name => $key) {
      $statements[] = $this->_createIndexSql($name, $key_name, $key);
    }
  }
  // Add table comment.
  if (!empty($table['description'])) {
    $statements[] = 'COMMENT ON TABLE {' . $name . '} IS ' . $this->prepareComment($table['description']);
  }
  // Add column comments.
  foreach ($table['fields'] as $field_name => $field) {
    if (!empty($field['description'])) {
      $statements[] = 'COMMENT ON COLUMN {' . $name . '}.' . $field_name . ' IS ' . $this->prepareComment($field['description']);
    }
  }
  return $statements;
}Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
