]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/commit
Pull Request: Add Support for `TABLESPACE` Specification in Table Definitions for...
authorMiguel Grillo <miguel_grillo_orellana@hotmail.com>
Sun, 20 Oct 2024 22:13:58 +0000 (00:13 +0200)
committerMiguel Grillo <miguel_grillo_orellana@hotmail.com>
Sun, 20 Oct 2024 22:13:58 +0000 (00:13 +0200)
commitc2ab89afa01da639006e3875ff8357ebb4659346
treeb494926969d3b9865e6ce2f486c36acb1d1c9753
parent7495b51f9ae53b3a5c631d38397f5b9fece52015
Pull Request: Add Support for `TABLESPACE` Specification in Table Definitions for Oracle

**Description**

This PR adds support for specifying the `TABLESPACE` in table definitions in SQLAlchemy, specifically for Oracle. This feature is particularly useful for Oracle users who need to specify the tablespace where the table data will be stored.

**Changes Made**
1. Updated `construct_arguments` in `OracleDialect`:
    - The `construct_arguments` list in the `OracleDialect` class has been updated to include the `tablespace` argument for the `Table` class.

```Python
construct_arguments = [
    (
        sa_schema.Table,
        # old
        {"resolve_synonyms": False, "on_commit": None, "compress": False},
        # new
        {"resolve_synonyms": False, "on_commit": None, "compress": False, "tablespace": None},
    ),
    (sa_schema.Index, {"bitmap": False, "compress": False}),
]
```
**Path**: `lib/sqlalchemy/dialects/oracle/base.py`

2. Modified OracleDDLCompiler to Include TABLESPACE in post_create_table:
    - The OracleDDLCompiler class has been modified to include the TABLESPACE clause at the end of the CREATE TABLE statement if the tablespace option is provided.

```Python
if opts["tablespace"]:
    tablespace_name = opts["tablespace"]
    table_opts.append(
        "\n TABLESPACE %s" % self.preparer.quote(tablespace_name)
    )
```
**Path**: `lib/sqlalchemy/dialects/oracle/base.py`

3. Added tablespace Argument to the Table Class:
    - A new tablespace argument has been added to the Table class to allow specifying the tablespace in the table definition.

4. Documentation Update:
    - The documentation has been updated to reflect the new feature and provide usage examples.

**Usage Example**

```Python
from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData

engine = create_engine('oracle+cx_oracle://user:password@dsn')

metadata = MetaData()

users = Table('users', metadata,
    Column('id', Integer, primary_key=True),
    Column('name', String),
    Column('email', String, unique=True),
    oracle_tablespace='my_tablespace'  # New tablespace argument optional
)

metadata.create_all(engine)
```
lib/sqlalchemy/dialects/oracle/base.py