【问题标题】:How to use postgres numeric range with SQLAlchemy如何在 SQLAlchemy 中使用 postgres 数值范围
【发布时间】:2014-06-27 03:24:21
【问题描述】:

除了this 之外,在 SQLAlchemy 中使用 Postgres 范围类型时,我碰巧找不到很多东西。有谁知道如何将新列值插入到 numrange 列中?有没有人有一些代码 sn-ps 或比我已经找到的更多的文档?

【问题讨论】:

    标签: python postgresql sqlalchemy


    【解决方案1】:

    这已经被添加到官方文档中:https://bitbucket.org/zzzeek/sqlalchemy/issue/3046/postgresql-range-types-need-better


    不得不为此进行挖掘,但如果有疑问,请检查测试! SQLAlchemy tests for the range types 使用底层的psycopg2 types

    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()
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-11-13
      • 1970-01-01
      • 2017-09-06
      • 1970-01-01
      • 2021-03-07
      • 1970-01-01
      相关资源
      最近更新 更多