sqlalchemy批量插入(存在唯一约束)

插入oracle时,如果某个列存在唯一约束,同时批量插入时数据重复,会报error,此时将error的过滤掉,最后commit

def insert_one_by_one():
    from sqlalchemy import create_engine
    engine = create_engine("oracle://user:pass@xx.xx.xx.xx:xxxx/?service_name=xxx.xxx.xxx", echo=True)

    user_list = [{'username': 'jalen1', 'age': '11', 'height': '123'},
                 {'username': 'jalen2', 'age': '12', 'height': '124'},
                 {'username': 'jalen3', 'age': '13', 'height': '125'},
                 {'username': 'jalen4', 'age': '14', 'height': None}]

    conn = engine.connect()
    trans = conn.begin()
    try:
        for user in user_list:
            try:
                sql = "INSERT INTO tb_user(username, age, height) VALUES('{0}', '{1}', '{2}')".\
                    format(user['username'], user['age'], user['height'])
                conn.execute(sql)
            except Exception as e:
                logger.info(e.message)
        trans.commit()
    except Exception:
        trans.rollback()
        raise
    finally:
        conn.close()

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值