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

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何將記錄從一張表轉(zhuǎn)移到另一張表?

如何將記錄從一張表轉(zhuǎn)移到另一張表?

回首憶惘然 2023-05-09 10:42:05
我有以下示例表:class DestDB(Base):    __tablename__ = "dest_db"    __table_args__ = (Index('nameplace', "name", "place"))    id = Column(Integer, primary_key=True)    name = Column(String(100))    place = Column(String(100))我很習(xí)慣使用字典來添加記錄。例如:dict = {"name": "foo", "place": "bar"}session.add(DestDB(**dict))但是,如何將記錄從一張表轉(zhuǎn)移到另一張表?我想我可以查詢?cè)幢?,遍歷每條記錄,將其轉(zhuǎn)換成字典,然后添加上面的結(jié)果。但是,我確定必須有一個(gè)更簡潔的解決方案?源數(shù)據(jù)庫中會(huì)有重復(fù)的name和place記錄組合,所以我不想使用任何類型的批量操作,除非它不會(huì)插入任何重復(fù)記錄。假設(shè)源數(shù)據(jù)庫如下所示:class SourceDB(Base):    __tablename__ = "source_db"    id = Column(Integer, primary_key=True)    name = Column(String(100))    place = Column(String(100))我只想傳輸name和place字段。
查看完整描述

1 回答

?
智慧大石

TA貢獻(xiàn)1946條經(jīng)驗(yàn) 獲得超3個(gè)贊

我建議堅(jiān)持使用The Zen of Python。


顯式優(yōu)于隱式。


我會(huì)在 ? 上實(shí)現(xiàn)一個(gè)方法SourceDB來提供我想要的對(duì)象的字典格式。


class SourceDB(Base):

    __tablename__ = "source_db"


    id = Column(Integer, primary_key=True)

    name = Column(String(100))

    place = Column(String(100))


    def as_dict(self):

        return dict(name=self.name, place=self.place)

并像這樣使用它


session.add(DestDB(**src_obj.as_dict()))

盡管您可以更動(dòng)態(tài)地執(zhí)行此操作,但我仍然建議使用更明確的方法。


class SourceDB(Base):

    __tablename__ = "source_db"


    id = Column(Integer, primary_key=True)

    name = Column(String(100))

    place = Column(String(100))


    def as_dict(self, fields):

        return dict(field: getattr(self, field) for field in fields if hasattr(self, field))

并這樣做


session.add(DestDB(src_obj.as_dict(("name", "place"))))


查看完整回答
反對(duì) 回復(fù) 2023-05-09
  • 1 回答
  • 0 關(guān)注
  • 147 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號(hào)

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