blob: 3ebbf6638978b04530029491ebfe81d4d9af9f9e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
from typing import cast
from sqlalchemy import Column
from sqlalchemy import Integer
from sqlalchemy.orm import declarative_base
from sqlalchemy.orm import Mapped
from sqlalchemy.orm import query_expression
from sqlalchemy.orm import Session
from sqlalchemy.orm import with_expression
Base = declarative_base()
class User(Base):
__tablename__ = "users"
id = Column(Integer, primary_key=True)
foo = Column(Integer)
question_count: Mapped[int] = query_expression()
answer_count: int = query_expression()
s = Session()
q = s.query(User).options(with_expression(User.question_count, User.foo + 5))
u1: User = cast(User, q.first())
qc: int = u1.question_count
print(qc)
|