Я создаю небольшую базу данных sqlite, чтобы управлять парсингом веб-страниц. У меня есть такие запросы.
async def get_by_title(session: AsyncSession, title: str) -> Optional[Manga]:
query = select(Manga).where(Manga.title == title).limit(1)
result = await session.scalar(query)
return result
Моя проблема заключается в том, что я все время выбираю, использую ли я session.execute, session.scalar или session.scalars, все возвращают объект кортежа строки, и если я использую скаляр/один/первый и т. д., я получите только самый первый элемент объекта (то есть идентификатор). Судя по документации, это не кажется правильным. Чего мне не хватает?
from .base import Base
from datetime import datetime
from sqlalchemy import func
from sqlalchemy.orm import Mapped, mapped_column
from sqlalchemy.dialects.sqlite import INTEGER, TEXT, DATETIME
class Manga(Base):
__tablename__ = 'manga'
manga_id: Mapped[int] = mapped_column(INTEGER,primary_key=True,autoincrement=True)
title: Mapped[str] = mapped_column(TEXT,nullable=False)
language: Mapped[str] = mapped_column(TEXT,nullable=False)
path_key: Mapped[str] = mapped_column(TEXT,nullable=False)
created_at: Mapped[datetime] = mapped_column(DATETIME,nullable=False,default=func.now())
from sqlalchemy.orm import DeclarativeBase
class Base(DeclarativeBase):
pass
Примечание: если я перебираю строки, я получаю кортеж со всей соответствующей информацией
async def print_rows(session: AsyncSession, title: str):
query = select(Manga).where(Manga.title == title)
result = await session.execute(query)
for row in result:
print(row) # (manga_id,title,language,path_key,created_at) all as expected
Подробнее здесь: https://stackoverflow.com/questions/793 ... rm-objects
Sqlalchemy 2.x не анализирует объекты ORM ⇐ Python
Программы на Python
1736725472
Anonymous
Я создаю небольшую базу данных sqlite, чтобы управлять парсингом веб-страниц. У меня есть такие запросы.
async def get_by_title(session: AsyncSession, title: str) -> Optional[Manga]:
query = select(Manga).where(Manga.title == title).limit(1)
result = await session.scalar(query)
return result
Моя проблема заключается в том, что я все время выбираю, использую ли я session.execute, session.scalar или session.scalars, все возвращают объект кортежа строки, и если я использую скаляр/один/первый и т. д., я получите только самый первый элемент объекта (то есть идентификатор). Судя по документации, это не кажется правильным. Чего мне не хватает?
from .base import Base
from datetime import datetime
from sqlalchemy import func
from sqlalchemy.orm import Mapped, mapped_column
from sqlalchemy.dialects.sqlite import INTEGER, TEXT, DATETIME
class Manga(Base):
__tablename__ = 'manga'
manga_id: Mapped[int] = mapped_column(INTEGER,primary_key=True,autoincrement=True)
title: Mapped[str] = mapped_column(TEXT,nullable=False)
language: Mapped[str] = mapped_column(TEXT,nullable=False)
path_key: Mapped[str] = mapped_column(TEXT,nullable=False)
created_at: Mapped[datetime] = mapped_column(DATETIME,nullable=False,default=func.now())
from sqlalchemy.orm import DeclarativeBase
class Base(DeclarativeBase):
pass
Примечание: если я перебираю строки, я получаю кортеж со всей соответствующей информацией
async def print_rows(session: AsyncSession, title: str):
query = select(Manga).where(Manga.title == title)
result = await session.execute(query)
for row in result:
print(row) # (manga_id,title,language,path_key,created_at) all as expected
Подробнее здесь: [url]https://stackoverflow.com/questions/79350895/sql-alchemy-2-x-not-parsing-orm-objects[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия