20260511-Pydantic和SQLalchemy

记录auditflow(见20260510)的pydantic和SQlAlchemy用法 今天主要记录配置加载和factory初始化部分

Pydantic

python 复制代码
@field_validator("xxx", mode="before/after")
@classmethod
def _function(cls, v: str) -> str:
    return 
  • @field_validator,用于读取env文件中xxx
  • before,在pydantic加载xxx前调用,可用于规范大小写,检查是否合法等
  • after,在pydantic加载xxx后且被before处理后调用,可用info.data使用处理后的值
  • cls,validator所属的类
  • v,xxx原始字符
  • @model_validator,在整个模型的所有字段验证都完成后运行,接收完整的 self(已填充/已验证的模型实例)。适合跨字段组合或衍生字段(比如把多个 POSTGRES_* 组合成 database_url
python 复制代码
class _DictSettings(AppRuntimeSettings):
    model_config = SettingsConfigDict(
        env_file=None,
        env_ignore_empty=True,
        extra="ignore",
        populate_by_name=True,
    )

    @classmethod
    def settings_customise_sources(cls, settings_cls, init_settings, **kwargs):
        return (init_settings,)
  • SettingConfigDict,用来管理应用配置
  • setting_cls,当前正被构造的Setting类(_DictSettings)
  • init_settings,初始化参数配置源
  • **kwargs,捕获可能传入的其他参数

运行顺序:构造函数->settings_customise_sources->@field_validator("xxx", mode="before/after")->@model_validator(mode="after")

SQLalchemy

  • creat_engine:数据库连接引擎,不直接连接数据库,自带连接池和dialect(将SQLAlchemy代码翻译为特定数据库能看懂的语言)
  • sessionmaker:一个可调用的工厂,用于创建session(session用于orm增删改查操作)
  • DeclarativeBase:声明式映射基类,表结构直接继承该类,SQLAlchemy自动生成对应的Table对象,并简历类属性与数据库列的映射关系
  • Base.metadata.create_all(engine):创建所有表,多次安全调用,只会创建不存在的表,不会修改已存在表的列或约束
python 复制代码
@contextmanager
def session_scope(self):
    session: Session = self._sessionmaker()
    try:
        yield session
        session.commit()
    except Exception:
        session.rollback()
        raise
    finally:
        session.close()

可with调用,yield一个session,在session中做完操作后commit,出现异常进行回滚,执行完后关闭session

python 复制代码
@contextmanager
def transactional(self):
    """Yield a session for use across multiple repository calls in one transaction."""
    session: Session = self._sessionmaker()
    try:
        yield session
        session.commit()
    except Exception:
        session.rollback()
        raise
    finally:
        session.close()

和上面的代码一模一样,一个用来在单个session中执行单个sql,一个用来保证业务原子性,多个repository需要执行时在一个transcational中执行

  • session.get:使用主键获取对应表的信息
  • session.add:在表中插入数据

未完待续...

小结

AI coding参与的多了项目不像是自己的,得多审阅,静下心来好好看代码逻辑和设计,将其消化为自己的能力

相关推荐
yexuhgu1 小时前
如何为禁用按钮点击添加提示文案
jvm·数据库·python
水木流年追梦1 小时前
大模型入门-应用篇1-prompt技术
开发语言·python·算法·prompt
smallYoung1 小时前
【学习笔记】中间件-RabbitMQ
后端
莫生灬灬1 小时前
ElementUI封装 共91个组件 支持易语言/火山/C#/Python
开发语言·c++·python·ui·elementui·c#
三千星1 小时前
Java开发者转型AI工程化Week 3:从LangChain4j到AI Agent
后端·langchain
WL_Aurora1 小时前
【每日一题】位运算
python·算法
duke8692672141 小时前
JavaScript数组扁平化flat与flatMap处理嵌套数据
jvm·数据库·python
小糖学代码1 小时前
LLM系列:3.nlp基础入门:nlp与循环神经网络
人工智能·pytorch·python·rnn·深度学习·神经网络·自然语言处理
m0_740796361 小时前
mysql如何通过脚本自动化创建用户_使用shell配合mysql命令
jvm·数据库·python