Skip to content

高级用法

async def update_model_by_column(
    self,
    session: AsyncSession,
    obj: UpdateSchema | dict[str, Any],
    allow_multiple: bool = False,
    flush: bool = False,
    commit: bool = False,
    **kwargs,
) -> int:
  • 此方法提供 flush 参数,详见:冲洗
  • 此方法提供 commit 参数,详见:提交
  • 此方法可结合 高级过滤器 使用

更新多条

将参数 allow_multiple 设置为 True,将允许更新多条记录,更新的数量取决于过滤器过滤后的数据

示例

update_model_by_columnn
from pydantic import BaseModel

from sqlalchemy_crud_plus import CRUDPlus

from sqlalchemy import DeclarativeBase as Base
from sqlalchemy.ext.asyncio import AsyncSession


class ModelIns(Base):
    # your sqlalchemy model
    pass


class UpdateIns(BaseModel):
    # your pydantic schema
    pass


class CRUDIns(CRUDPlus[ModelIns]):
    async def create(self, db: AsyncSession, obj: UpdateIns) -> int:
        return await self.update_model_by_column(db, obj, name="foo")