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
33
34
35
36
37
38
39
40
41
|
"""Common Database connection protocols."""
from typing import Any, Protocol
class DbConnection(Protocol):
"""Type annotation for a generic database connection object."""
def cursor(self, *args, **kwargs) -> Any:
"""A cursor object"""
...
def commit(self) -> Any:
"""Commit the transaction."""
...
def rollback(self) -> Any:
"""Rollback the transaction."""
...
class DbCursor(Protocol):
"""Type annotation for a generic database cursor object."""
def execute(self, *args, **kwargs) -> Any:
"""Execute a single query"""
...
def executemany(self, *args, **kwargs) -> Any:
"""
Execute parameterized SQL statement sql against all parameter sequences
or mappings found in the sequence parameters.
"""
...
def fetchone(self, *args, **kwargs):
"""Fetch single result if present, or `None`."""
...
def fetchmany(self, *args, **kwargs):
"""Fetch many results if present or `None`."""
...
def fetchall(self, *args, **kwargs):
"""Fetch all results if present or `None`."""
...
|