Function Table

  • A class decorator for defining and customizing the table metadata associated with an entity class within the ORM system. This decorator enriches the entity with additional metadata, specifying how the entity relates to the underlying database table. By providing custom table options, such as table names or schema definitions, this decorator plays a crucial role in bridging the gap between the ORM's abstract entities and their concrete database representations.

    IMPORTANT - All entity classes should extend a table

    Parameters

    • props: TableMetadataOptions

      The TableMetadataOptions object containing metadata configuration for the table. This can include options like the table's name, delimiter and default field customizations.

    Returns (target: typeof default, context: ClassDecoratorContext) => void

    A class decorator factory function that takes a target class extending DynaRecord and a context object provided by the TypeScript runtime. The decorator function registers the provided metadata options with the ORM's metadata system, ensuring the entity is properly configured and recognized by the ORM.

    Usage example:

    @Table({ name: 'my-table', delimiter: '"#",' })
    class MyTable extends DynaRecord {
    // User entity implementation
    }

    In this example, the @Table decorator is applied to the User class, specifying custom table metadata options, including the table name (users) and the schema (public). These options are registered with the ORM, which then uses them to correctly map the User entity to the corresponding table in the database. This mapping is critical for executing ORM operations such as querying, inserting, and updating records in the users table.