Open
Description
Description
There is a discrepancy between the documentation for numeric types and what appears when creating a numeric column:
Field [some_field] has precision [some_precision] and scale [some_scale] but precision and scale for NUMERIC must be: 0 <= precision - scale <= 29
from the BigQuery Console
Environment details
- OS type and version:
- Python version:
Python 3.11.10
- pip version:
pip 24.0
sqlalchemy-bigquery
version:Version: 1.12.0
Steps to reproduce
- Attempt to make a table with a column of type
NUMERIC
withprecision=37
andscale=0
using SQLAlchemy
Code example
import sqlalchemy as sa
from sqlalchemy_bigquery._types import NUMERIC
engine = sa.create_engine("bigquery://")
table = sa.Table(
"test", sa.MetaData(...), sa.Column("id", NUMERIC(37, 0), primary_key=True)
)
table.create(engine)
Stack trace
DatabaseError: (google.cloud.bigquery.dbapi.exceptions.DatabaseError) 400 POST https://bigquery.googleapis.com/bigquery/v2/projects/govis-sandbox/queries?prettyPrint=false: In NUMERIC(P, 0), P must be between
1 and 29 at [3:27]