猿问

具有多个条件的 SQLAlchemy CheckConstraint 会引发警告

我正在使用 SQLAlchemy 1.3.18、Python 3.8.5 和 PostgreSQL 12。


我有下表声明,其中包含具有多个列和条件的检查约束:


Table(

    'my_table',

    MetaData(),

    Column('id', Integer, primary_key=True),

    Column('start', DateTime(), nullable=False),

    Column('end', DateTime(), nullable=False),

    CheckConstraint(

        and_(

            or_(

                func.date_trunc('month', column('start')) == func.date_trunc('month', column('end')),

                func.extract('day', column('end')) == 1

            ),

            (column('end') - (column('start') + func.make_interval(0, 1)) <= func.make_interval())

        )

    )

)

尽管应用程序确实在数据库中正确创建了检查约束,但我收到以下警告:


C:\Python38\lib\site-packages\sqlalchemy\sql\base.py:559: SAWarning: 表 None 上的列“end”被 <sqlalchemy.sql.elements.ColumnClause 替换为 0x26522ab0e50;end>,具有相同的密钥。考虑 select() 语句的 use_labels。


C:\Python38\lib\site-packages\sqlalchemy\sql\base.py:559: SAWarning: 表上的列“start” None 被 0x26522ab0b80 处的 <sqlalchemy.sql.elements.ColumnClause 替换;start>,具有相同的键。考虑 select() 语句的 use_labels。


C:\Python38\lib\site-packages\sqlalchemy\sql\base.py:559: SAWarning: 表 None 上的列“end”被 0x26522ab0c70 处的 <sqlalchemy.sql.elements.ColumnClause 替换;end>,具有相同的密钥。考虑 select() 语句的 use_labels。


我做错了什么?


斯蒂芬大帝
浏览 88回答 1
1回答

慕码人2483693

这就是解决方案,将列放入变量中,以便它们在内存中是同一对象。my_table_start = column('start')my_table_end = column('end')Table(&nbsp; &nbsp; 'my_table',&nbsp; &nbsp; MetaData(),&nbsp; &nbsp; Column('id', Integer, primary_key=True),&nbsp; &nbsp; Column('start', DateTime(), nullable=False),&nbsp; &nbsp; Column('end', DateTime(), nullable=False),&nbsp; &nbsp; CheckConstraint(&nbsp; &nbsp; &nbsp; &nbsp; and_(&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; or_(&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; func.date_trunc('month', my_table_start) == func.date_trunc('month', my_table_end),&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; func.extract('day', my_table_end) == 1&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; ),&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; (my_table_end - (my_table_start + func.make_interval(0, 1)) <= func.make_interval())&nbsp; &nbsp; &nbsp; &nbsp; )&nbsp; &nbsp; ))
随时随地看视频慕课网APP

相关分类

Python
我要回答