Exemple #1
0
 async def list_cities(self) -> AsyncIterator[models.City]:
     result = await self._conn.stream(sqlalchemy.text(LIST_CITIES))
     async for row in result:
         yield models.City(
             slug=row[0],
             name=row[1],
         )
Exemple #2
0
 async def get_city(self, *, slug: str) -> Optional[models.City]:
     row = (await self._conn.execute(sqlalchemy.text(GET_CITY), {"p1": slug})).first()
     if row is None:
         return None
     return models.City(
         slug=row[0],
         name=row[1],
     )
Exemple #3
0
 async def create_city(self, *, name: str, slug: str) -> Optional[models.City]:
     row = (await self._conn.execute(sqlalchemy.text(CREATE_CITY), {"p1": name, "p2": slug})).first()
     if row is None:
         return None
     return models.City(
         slug=row[0],
         name=row[1],
     )