如何使用SQLAlchemy与PostgreSQL的数字范围?

9
我找不到关于在SQLAlchemy中使用Postgres范围类型的更多信息,除了this。有人知道如何将新列值插入到numrange列中吗?有人有比我已经找到的更多的代码片段或文档吗?
1个回答

9
这已添加到官方文档:https://bitbucket.org/zzzeek/sqlalchemy/issue/3046/postgresql-range-types-need-better
需要查找信息时,请查看测试!SQLAlchemy 范围类型的测试使用底层psycopg2类型
from psycopg2.extras import NumericRange
from sqlalchemy import create_engine, Column, Integer
from sqlalchemy.dialects.postgresql import INT4RANGE
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

engine = create_engine('postgresql:///example', echo=True)
Session = sessionmaker(bind=engine)
session = Session()
Base = declarative_base(bind=engine)


class Example(Base):
    __tablename__ = 'example'

    id = Column(Integer, primary_key=True)
    window = Column(INT4RANGE, nullable=False)


Base.metadata.create_all()

session.add(Example(window=NumericRange(2, 6)))
session.add(Example(window=NumericRange(4, 8)))
session.commit()

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接