利用Python跨服务器、跨数据库类型高效插入数据

#1、加载所需要的包

import pymysql
import time
time1 = time.time()

#2、查询的数据表

db2 = pymysql.connect('112.128.0.001', 'root', '123456', 'db')
cursor2 = db2.cursor()
len2 = cursor2.execute('SELECT * from xxxx')

#3、插入的数据表

db1=pymysql.connect('localhost','root','123456','db')
cursor1=db1.cursor()
sql="insert into xxxx" \
    "(a,b,c,d,e,f,g,r,s,t,j)" \
    " value(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"

4、事务加批量插入

num = 11
for i in range(int(len2 / num)):
    # print(i)
    # 获取num条记录
    data1 = cursor2.fetchmany(num)
    # executemany能同时执行多条语句,第一个参数为sql模板字符串,第二个为sql的参数,是一个列表
    cursor1.executemany(sql, data1)

5、最后一次性全部导入

data2 = cursor2.fetchall()
cursor1.executemany(sql, data2)

db1.commit()
db1.close()
db2.close()
print(time.time() - time1)

最后我插入1000万数据大概耗时100s,是不是很快呢,喜欢这篇文章就点击一下关注吧。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
插入数据数据库可以使用 Python 中的 MySQLdb、pymysql 或者 sqlite3 等库。下面以 MySQLdb 为例进行示范。 首先需要安装 MySQLdb 库,可以使用 pip install MySQL-python 进行安装。 接着,连接数据库插入数据的代码如下所示: ```python import MySQLdb # 打开数据库连接 db = MySQLdb.connect("localhost", "username", "password", "database_name") # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 插入语句 sql = "INSERT INTO table_name(column1, column2, column3) VALUES ('value1', 'value2', 'value3')" try: # 执行sql语句 cursor.execute(sql) # 提交到数据库执行 db.commit() except: # 如果发生错误则回滚 db.rollback() # 关闭数据库连接 db.close() ``` 其中,需要替换的部分是: - `localhost`:数据库服务器地址; - `username`:数据库用户名; - `password`:数据库密码; - `database_name`:数据库名称; - `table_name`:需要插入数据的表名; - `column1`、`column2`、`column3`:需要插入数据的列名; - `value1`、`value2`、`value3`:具体的数据值。 如果需要插入多条数据,可以将 SQL 插入语句修改为以下形式: ```python sql = "INSERT INTO table_name(column1, column2, column3) VALUES (%s, %s, %s)" values = [ ('value1', 'value2', 'value3'), ('value4', 'value5', 'value6'), ('value7', 'value8', 'value9'), ] try: # 执行sql语句 cursor.executemany(sql, values) # 提交到数据库执行 db.commit() except: # 如果发生错误则回滚 db.rollback() ``` 其中,`values` 是一个包含多组数据的列表,每组数据用元组表示。`executemany()` 方法可以批量插入数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值