-
Notifications
You must be signed in to change notification settings - Fork 138
Open
Labels
api: bigqueryIssues related to the googleapis/python-bigquery-sqlalchemy API.Issues related to the googleapis/python-bigquery-sqlalchemy API.
Description
Example:
class Base(DeclarativeBase):
pass
class User(Base):
__tablename__ = "users"
__table_args__ = {"schema": "app"}
# Not a real column - just here to satisfy SQLAlchemy's requirement for a primary key for every table
id: Mapped[int] = orm.mapped_column(
BigInteger, primary_key=True, autoincrement=True
)
email: Mapped[Optional[str]] = orm.mapped_column(String)
The following code fails:
engine = create_engine("bigquery://", echo=True)
Base.metadata.create_all(engine)
row = User(email="[email protected]")
with Session(engine) as session:
with session.begin():
session.add(row)
FlushError: Instance <User at 0xffff90209d30> has a NULL identity key. If this is an auto-generated value, check that the database table allows generation of new primary key values, and that the mapped Column object is configured to expect these generated values. Ensure also that this flush() is not occurring at an inappropriate time, such as within a load() event.
Metadata
Metadata
Assignees
Labels
api: bigqueryIssues related to the googleapis/python-bigquery-sqlalchemy API.Issues related to the googleapis/python-bigquery-sqlalchemy API.