feat(mixin): add TableBaseMixin and UUIDTableBaseMixin for async CRUD operations

- Implemented TableBaseMixin providing generic CRUD methods and automatic timestamp management.
- Introduced UUIDTableBaseMixin for models using UUID as primary keys.
- Added ListResponse for standardized paginated responses.
- Created TimeFilterRequest and PaginationRequest for filtering and pagination parameters.
- Enhanced get_with_count method to return both item list and total count.
- Included validation for time filter parameters in TimeFilterRequest.
- Improved documentation and usage examples throughout the code.
This commit is contained in:
2025-12-22 18:29:14 +08:00
parent 47a4756227
commit a5efda9c23
44 changed files with 4306 additions and 497 deletions

View File

@@ -1,9 +1,10 @@
from typing import Literal
from enum import StrEnum
from sqlmodel import Field, UniqueConstraint
from .base import TableBase, SQLModelBase
from enum import StrEnum
from .base import SQLModelBase
from .mixin import TableBaseMixin
# ==================== DTO 模型 ====================
@@ -72,7 +73,7 @@ class SettingsType(StrEnum):
WOPI = "wopi"
# 数据库模型
class Setting(TableBase, table=True):
class Setting(SQLModelBase, TableBaseMixin):
"""设置模型"""
__table_args__ = (UniqueConstraint("type", "name", name="uq_setting_type_name"),)