我正在使用 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。
我做错了什么?
慕码人2483693
相关分类