第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

具有多個條件的 SQLAlchemy CheckConstraint 會引發(fā)警告

具有多個條件的 SQLAlchemy CheckConstraint 會引發(fā)警告

斯蒂芬大帝 2023-07-18 15:16:00
我正在使用 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())        )    ))盡管應(yīng)用程序確實在數(shù)據(jù)庫中正確創(chuàng)建了檢查約束,但我收到以下警告: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條經(jīng)驗 獲得超9個贊

這就是解決方案,將列放入變量中,以便它們在內(nèi)存中是同一對象。


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

        )

    )

)


查看完整回答
反對 回復(fù) 2023-07-18
  • 1 回答
  • 0 關(guān)注
  • 116 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號