2025-02-14 17:42:36 +08:00
|
|
|
|
{% set pkField = pkColumn.python_field %}
|
|
|
|
|
|
{% set pk_field = pkColumn.python_field | camel_to_snake %}
|
2025-02-16 23:29:15 +08:00
|
|
|
|
{% set pkParentheseIndex = pkColumn.column_comment.find("(") %}
|
|
|
|
|
|
{% set pk_field_comment = pkColumn.column_comment[:pkParentheseIndex] if pkParentheseIndex != -1 else pkColumn.column_comment %}
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% set vo_field_required = namespace(has_required=False) %}
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{% if column.required %}
|
|
|
|
|
|
{% set vo_field_required.has_required = True %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% if table.sub %}
|
|
|
|
|
|
{% set sub_vo_field_required = namespace(has_required=False) %}
|
|
|
|
|
|
{% for sub_column in subTable.columns %}
|
|
|
|
|
|
{% if sub_column.required %}
|
|
|
|
|
|
{% set sub_vo_field_required.has_required = True %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% endif %}
|
2025-02-16 23:29:15 +08:00
|
|
|
|
{% for vo_import in voImportList %}
|
|
|
|
|
|
{{ vo_import }}
|
|
|
|
|
|
{% endfor %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
from pydantic import BaseModel, ConfigDict, Field
|
|
|
|
|
|
from pydantic.alias_generators import to_camel
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% if vo_field_required.has_required %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
from pydantic_validation_decorator import NotBlank
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% if table.sub %}
|
|
|
|
|
|
from typing import List, Optional
|
|
|
|
|
|
{% else %}
|
2025-02-16 23:29:15 +08:00
|
|
|
|
from typing import Optional
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% endif %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
from module_admin.annotation.pydantic_annotation import as_query
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-02-18 17:46:37 +08:00
|
|
|
|
{% if table.sub %}
|
|
|
|
|
|
class {{ BusinessName }}BaseModel(BaseModel):
|
2025-02-14 17:42:36 +08:00
|
|
|
|
"""
|
|
|
|
|
|
{{ functionName }}表对应pydantic模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
|
|
|
|
|
|
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{{ column.column_name }}: Optional[{{ column.python_type }}] = Field(default=None, description='{{ column.column_comment }}')
|
|
|
|
|
|
{% endfor %}
|
2025-02-18 17:46:37 +08:00
|
|
|
|
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{% if column.required %}
|
|
|
|
|
|
{% set parentheseIndex = column.column_comment.find("(") %}
|
|
|
|
|
|
{% set comment = column.column_comment[:parentheseIndex] if parentheseIndex != -1 else column.column_comment %}
|
|
|
|
|
|
@NotBlank(field_name='{{ column.column_name }}', message='{{ comment }}不能为空')
|
|
|
|
|
|
def get_{{ column.column_name }}(self):
|
|
|
|
|
|
return self.{{ column.column_name }}
|
|
|
|
|
|
{% if not loop.last %}{{ "\n" }}{% endif %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
|
|
|
|
{% if vo_field_required.has_required %}
|
|
|
|
|
|
def validate_fields(self):
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{% if column.required %}
|
|
|
|
|
|
self.get_{{ column.column_name }}()
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class {{ BusinessName }}Model({% if table.sub %}{{ BusinessName }}BaseModel{% else %}BaseModel{% endif %}):
|
|
|
|
|
|
"""
|
|
|
|
|
|
{{ functionName }}表对应pydantic模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
{% if not table.sub %}
|
|
|
|
|
|
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
|
|
|
|
|
|
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{{ column.column_name }}: Optional[{{ column.python_type }}] = Field(default=None, description='{{ column.column_comment }}')
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% endif %}
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% if table.sub %}
|
|
|
|
|
|
{{ subclassName }}_list: Optional[List['{{ subTable.business_name | capitalize }}Model']] = Field(default=None, description='子表列信息')
|
|
|
|
|
|
{% endif %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
|
2025-02-18 17:46:37 +08:00
|
|
|
|
{% if not table.sub %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{% if column.required %}
|
|
|
|
|
|
{% set parentheseIndex = column.column_comment.find("(") %}
|
|
|
|
|
|
{% set comment = column.column_comment[:parentheseIndex] if parentheseIndex != -1 else column.column_comment %}
|
|
|
|
|
|
@NotBlank(field_name='{{ column.column_name }}', message='{{ comment }}不能为空')
|
|
|
|
|
|
def get_{{ column.column_name }}(self):
|
|
|
|
|
|
return self.{{ column.column_name }}
|
2025-02-18 17:46:37 +08:00
|
|
|
|
{% if not loop.last %}{{ "\n" }}{% endif %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% if vo_field_required.has_required %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
def validate_fields(self):
|
|
|
|
|
|
{% for column in columns %}
|
|
|
|
|
|
{% if column.required %}
|
|
|
|
|
|
self.get_{{ column.column_name }}()
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% endif %}
|
2025-02-18 17:46:37 +08:00
|
|
|
|
{% endif %}
|
2025-02-14 17:42:36 +08:00
|
|
|
|
|
|
|
|
|
|
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% if table.sub %}
|
|
|
|
|
|
class {{ subTable.business_name | capitalize }}Model(BaseModel):
|
|
|
|
|
|
"""
|
|
|
|
|
|
{{ subTable.function_name }}表对应pydantic模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
|
|
|
|
|
|
|
|
|
|
|
|
{% for sub_column in subTable.columns %}
|
|
|
|
|
|
{{ sub_column.column_name }}: Optional[{{ sub_column.python_type }}] = Field(default=None, description='{{ sub_column.column_comment}}')
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
|
|
|
|
{% for sub_column in subTable.columns %}
|
|
|
|
|
|
{% if sub_column.required %}
|
|
|
|
|
|
{% set parentheseIndex = sub_column.column_comment.find("(") %}
|
|
|
|
|
|
{% set comment = sub_column.column_comment[:parentheseIndex] if parentheseIndex != -1 else sub_column.column_comment %}
|
|
|
|
|
|
@NotBlank(field_name='{{ sub_column.column_name }}', message='{{ comment }}不能为空')
|
|
|
|
|
|
def get_{{ sub_column.column_name }}(self):
|
|
|
|
|
|
return self.{{ sub_column.column_name }}
|
2025-02-18 17:46:37 +08:00
|
|
|
|
{% if not loop.last %}{{ "\n" }}{% endif %}
|
2025-02-17 17:43:29 +08:00
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
|
|
|
|
{% if sub_vo_field_required.has_required %}
|
|
|
|
|
|
def validate_fields(self):
|
|
|
|
|
|
{% for sub_column in subTable.columns %}
|
|
|
|
|
|
{% if sub_column.required %}
|
|
|
|
|
|
self.get_{{ sub_column.column_name }}()
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-02-18 17:46:37 +08:00
|
|
|
|
class {{ BusinessName }}QueryModel({% if table.sub %}{{ BusinessName }}BaseModel{% else %}{{ BusinessName }}Model{% endif %}):
|
2025-02-14 17:42:36 +08:00
|
|
|
|
"""
|
|
|
|
|
|
{{ functionName }}不分页查询模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
begin_time: Optional[str] = Field(default=None, description='开始时间')
|
|
|
|
|
|
end_time: Optional[str] = Field(default=None, description='结束时间')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@as_query
|
|
|
|
|
|
class {{ BusinessName }}PageQueryModel({{ BusinessName }}QueryModel):
|
|
|
|
|
|
"""
|
|
|
|
|
|
{{ functionName }}分页查询模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
page_num: int = Field(default=1, description='当前页码')
|
|
|
|
|
|
page_size: int = Field(default=10, description='每页记录数')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Delete{{ BusinessName }}Model(BaseModel):
|
|
|
|
|
|
"""
|
|
|
|
|
|
删除{{ functionName }}模型
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
model_config = ConfigDict(alias_generator=to_camel)
|
|
|
|
|
|
|
|
|
|
|
|
{{ pk_field }}s: str = Field(description='需要删除的{{ pk_field_comment }}')
|