mirror of
https://github.com/fastapi-practices/fastapi_best_architecture.git
synced 2026-03-13 09:31:31 +08:00
* Refactor foreign keys and relationships to pure logic * Revert of some changes * More revert * Update the user paginate * Update user create and update * Update dept select and delete * Rename the join query functions * Update select_join_serialize doc and README * Fix typo in README * Update the user delete * Update the user social * Update the dict plugin crud * Update the dict plugin version * Bump dependencies and pre-commits * Update the code generator plugin crud * Update the menu crud * Update the role crud * Update the data scope and rule crud * Restore get_paginated to get_select * Update the code generator plugin version * Add the py version in pre-commit * Remove the plugin include parameter config * Add more cache cleaning TODO * Rename get_with_relation to get_join * Add the user cache clear * Fix known compatibility issues * Update the version number to 1.11.0 * Fix lint * Optimize select_join_serialize logic * Delete cache cleanup comments * Update the oauth2 plugin version * Fix user-role table cleanup when user update
26 lines
1.2 KiB
Python
26 lines
1.2 KiB
Python
import sqlalchemy as sa
|
|
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
|
|
from backend.common.model import DataClassBase, UniversalText, id_key
|
|
|
|
|
|
class GenColumn(DataClassBase):
|
|
"""代码生成模型列表"""
|
|
|
|
__tablename__ = 'gen_column'
|
|
|
|
id: Mapped[id_key] = mapped_column(init=False)
|
|
name: Mapped[str] = mapped_column(sa.String(64), comment='列名称')
|
|
comment: Mapped[str | None] = mapped_column(sa.String(256), default=None, comment='列描述')
|
|
type: Mapped[str] = mapped_column(sa.String(32), default='String', comment='SQLA 模型列类型')
|
|
pd_type: Mapped[str] = mapped_column(sa.String(32), default='str', comment='列类型对应的 pydantic 类型')
|
|
default: Mapped[str | None] = mapped_column(UniversalText, default=None, comment='列默认值')
|
|
sort: Mapped[int | None] = mapped_column(default=1, comment='列排序')
|
|
length: Mapped[int] = mapped_column(default=0, comment='列长度')
|
|
is_pk: Mapped[bool] = mapped_column(default=False, comment='是否主键')
|
|
is_nullable: Mapped[bool] = mapped_column(default=False, comment='是否可为空')
|
|
|
|
# 逻辑外键
|
|
gen_business_id: Mapped[int] = mapped_column(sa.BigInteger, default=0, comment='代码生成业务ID')
|