如何在SQLAlchemy中使用Postgres数值范围

9 投票
1 回答
4008 浏览
提问于 2025-04-18 05:58

我在网上找不到太多关于在SQLAlchemy中使用Postgres范围类型的信息,除了这个。有没有人知道怎么往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()

撰写回答