Compare commits
2 commits
6055c4ed3b
...
76921a2841
| Author | SHA1 | Date | |
|---|---|---|---|
| 76921a2841 | |||
| da6c767698 |
2 changed files with 7 additions and 5 deletions
|
|
@ -204,7 +204,7 @@ def age_pair(*, nullable: bool = False, **ka) -> tuple[Column, Column]:
|
|||
return (date_col, acc_col)
|
||||
|
||||
|
||||
def parent_children(keyword: str, /, **kwargs):
|
||||
def parent_children(keyword: str, /, *, lazy: str = 'selectin', **kwargs):
|
||||
"""
|
||||
Self-referential one-to-many relationship pair.
|
||||
Parent comes first, children come later.
|
||||
|
|
@ -214,13 +214,15 @@ def parent_children(keyword: str, /, **kwargs):
|
|||
|
||||
Additional keyword arguments can be sourced with parent_ and child_ argument prefixes,
|
||||
obviously.
|
||||
|
||||
CHANGED 0.5.0: the both relationship()s use lazy='selectin' attribute now by default.
|
||||
"""
|
||||
|
||||
parent_kwargs = kwargs_prefix(kwargs, 'parent_')
|
||||
child_kwargs = kwargs_prefix(kwargs, 'child_')
|
||||
|
||||
parent = Incomplete(relationship, Wanted(lambda o, n: o.__name__), back_populates=f'child_{keyword}s', **parent_kwargs)
|
||||
child = Incomplete(relationship, Wanted(lambda o, n: o.__name__), back_populates=f'parent_{keyword}', **child_kwargs)
|
||||
parent = Incomplete(relationship, Wanted(lambda o, n: o.__name__), back_populates=f'child_{keyword}s', lazy=lazy, **parent_kwargs)
|
||||
child = Incomplete(relationship, Wanted(lambda o, n: o.__name__), back_populates=f'parent_{keyword}', lazy=lazy, **child_kwargs)
|
||||
|
||||
return parent, child
|
||||
|
||||
|
|
|
|||
|
|
@ -45,10 +45,10 @@ class SQLAlchemy:
|
|||
def _ensure_engine(self):
|
||||
if self.engine is None:
|
||||
raise RuntimeError('database is not connected')
|
||||
async def begin(self) -> AsyncSession:
|
||||
async def begin(self, *, expire_on_commit = False, **kw) -> AsyncSession:
|
||||
self._ensure_engine()
|
||||
## XXX is it accurate?
|
||||
s = AsyncSession(self.engine)
|
||||
s = AsyncSession(self.engine, expire_on_commit=expire_on_commit, **kw)
|
||||
self._sessions.append(s)
|
||||
return s
|
||||
async def __aenter__(self) -> AsyncSession:
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue