我正在使用 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。我做錯了什么?
1 回答

慕碼人2483693
TA貢獻1860條經驗 獲得超9個贊
這就是解決方案,將列放入變量中,以便它們在內存中是同一對象。
my_table_start = column('start')
my_table_end = column('end')
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', my_table_start) == func.date_trunc('month', my_table_end),
func.extract('day', my_table_end) == 1
),
(my_table_end - (my_table_start + func.make_interval(0, 1)) <= func.make_interval())
)
)
)
添加回答
舉報
0/150
提交
取消