数据库—Python操作之Sqlalchemy库

sqlalchemy批量插入数据库

import sqlalchemy
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,String
from db import session

Base = declarative_base()


class User(Base):
    __tablename__="user"
    id = Column(Integer,primary_key=True)
    name_en = Column(String(32))

    def __repr__(self):
        return "<User(id='%s',name='%s')>"%(self.id,self.name)

user_list = []
for i in range(3):
     user_list.append({"id": "1c687b8f86ac42e981a235aa9da0d66a", "name": "name%s" % i})
     
 # 方式一:原生sql的方式批量插入
session.execute(User.__table__.insert(), user_list)
# 同样直接传入sql也可以
session.execute("INSERT INTO tb_name (id, name) VALUES ("1c687b8f86ac42e981a235aa9da0d66a", "jack"), ("5b60a71c0b294e13a8316422b170d4cd", "william"), (...)")

session.commit()

# 方式二:bulk_save_objects
objects = [
   User(**user) for user in user_list
]
s.bulk_save_objects(objects)
s.commit()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值