python - sqlalchemy 批次插入的資料,資料列不相等
伊谢尔伦
伊谢尔伦 2017-06-14 10:52:50
0
1
862
# 初始化数据库连接: engine = create_engine("xxxxx") # 创建DBSession类型: DBSession = sessionmaker(bind=engine) session = DBSession() # 测试没有问题的数据 rows_ok = [ {"name":"aaa","otherdata":"exist_col_aaa"}, {"name":"bbb","otherdata":"exist_col"}, ] # 测试出问题的数据 rows = [ {"name":"aaa"}, {"name":"bbb","otherdata":"exist_col"}, ] # User中有name,otherdata字段 session.execute(User.__table__.insert(),rows) session.commit() session.close()

如果批次插入資料中所有字典的key一致,則資料能保存

只要List中字典缺少一個key,會導致整個列被忽略

真實的情況列數很多,而且缺失資料也很多.有沒有解決辦法,或者使用其它方法?

或將

rows = [ {"name":"aaa"}, {"name":"aaa"}, {"name":"aaa"}, {"name":"aaa"}, {"name":"bbb","otherdata":"exist_col",....}, ]

轉化為

rows = [ {"name":"aaa","otherdata":"",....}, {"name":"aaa","otherdata":"",....}, {"name":"aaa","otherdata":"",....}, {"name":"aaa","otherdata":"",....}, {"name":"bbb","otherdata":"exist_col",....}, ]
伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回覆 (1)
習慣沉默
  1. schema定義的時候, 用nullable=False

  2. session.add_all

    最新下載
    更多>
    網站特效
    網站源碼
    網站素材
    前端模板
    關於我們 免責聲明 Sitemap
    PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!