欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python批量插入數(shù)據(jù)到mysql的3種方法

 更新時間:2023年10月26日 10:04:00   作者:Bobby?Wang  
這篇文章主要給大家介紹了關于python批量插入數(shù)據(jù)到mysql的3種方法,在日常處理數(shù)據(jù)的過程中,我們都有批量寫入數(shù)據(jù)庫的需求,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

自動化單條insert

# -*- coding:utf-8 -*-
import time
from pymysql import *

# 裝飾器,計算插入50000條數(shù)據(jù)需要的時間
def timer(func):
    def decor(*args):
        start_time = time.time()
        func(*args)
        end_time = time.time()
        d_time = end_time - start_time
        print("the running time is : ", d_time)

    return decor

@timer
def add_test_users():

    conn = connect(host='主機名', port='端口號', user='用戶名', password='密碼', database='數(shù)據(jù)庫名', charset='utf8')
    cs = conn.cursor() ?。!~@取游標
    for num in range(0, 58000):
        try:
            sql = "insert into '表名'(字段名) values(值)"
            cs.execute(sql)

        except Exception as e:
            return
            
    conn.commit() ?。!√峤?
    cs.close()
    conn.close()
    print('OK')

add_test_users()
  • 單條insert的話插入5w條數(shù)據(jù)大約用時5秒左右,相對來說效率不高

拼接sql語句,只執(zhí)行一次insert

# -*- coding:utf-8 -*-
import time
from pymysql import *

# 裝飾器,計算插入50000條數(shù)據(jù)需要的時間
def timer(func):
    def decor(*args):
        start_time = time.time()
        func(*args)
        end_time = time.time()
        d_time = end_time - start_time
        print("the running time is : ", d_time)

    return decor

@timer
def add_test_users():
    
    usersvalues = []
    for num in range(1, 50000):
        usersvalues.append(('需要插入的字段對應的value'))  # 注意要用兩個括號擴起來

    conn = connect(host='主機名', port='端口號', user='用戶名', password='密碼', database='數(shù)據(jù)庫名', charset='utf8')
    cs = conn.cursor()  # 獲取光標
    # 注意這里使用的是executemany而不是execute,下邊有對executemany的詳細說明
    cs.executemany('insert into '表名'(字段名) values(%s,%s,%s,%s)', usersvalues)

    conn.commit()
    cs.close()
    conn.close()
    print('OK')

add_test_users()

使用這種批量插入方式插入5w條數(shù)據(jù)用時大約不到1秒

另外,針對executemany
execute(sql) : 接受一條語句從而執(zhí)行
executemany(templet,args):能同時執(zhí)行多條語句,執(zhí)行同樣多的語句可比execute()快很多,強烈建議執(zhí)行多條語句時使用executemany
templet : sql模板字符串,  例如 ‘insert into table(id,name,age) values(%s,%s,%s)’
args: 模板字符串中的參數(shù),是一個list,在list中的每一個元素必須是元組!??!  例如: [(1,‘mike’),(2,‘jordan’),(3,‘james’),(4,‘rose’)]

使用load data infile 加載到mysql

需要注意的是,這種方式本來是在mysql里邊執(zhí)行的命令,而這里是用代碼實現(xiàn)的命令

如果是在linux下,需要進行下邊幾個步驟

在桌面寫個文本文件,里邊的內(nèi)容對應下邊的數(shù)據(jù)表字段即可

cd /var/lib/mysql-files/
切換到這個目錄,將文本文件移動到這個目錄下,如果不在這個目錄下執(zhí)行的話加載的時候會出現(xiàn)錯誤,當然也可以選擇修改mysql配置,只不過這種方法相對比較簡單

對應load data infile 可以在mysql里邊直接執(zhí)行文件即可
load data infile ‘/var/lib/mysql-files/data.txt’ into table ‘表名’(字段名)     這個命令

load data [low_priority] [local] infile ‘file_name txt’ [replace | ignore]
into table tbl_name
[fields
[terminated by’t’]
[OPTIONALLY] enclosed by ‘’]
[escaped by’’ ]]
[lines terminated by’n’]
[ignore number lines]
[(col_name, )]

這個是load data infile的完整命令,帶[ ]的是可選參數(shù) 下面解釋幾個比較常用的參數(shù)

[terminated by’t’] 這個意思就是文本字段里邊以什么分隔

如果文本文件是這樣:

小一,12,男
小二,13,女
小三,12,男

那么就是應該terminated by ’ , ’ ,不設置默認的就是制表符分隔,上邊定義的文本文件正好也就是制表符,因此沒有做設置,按照的就是默認值

==enclosed by == 這個的意思是字段是以什么包裹著

如果文本文件是這樣:

“小一”,“12”,“男”
“小二”,“13”,“女”
“小三”,“12”,“男”

那么參數(shù)就應該這樣寫:enclosed by “”

綜合以上三種方法比較,第三種方法效率最高,因此建議用第三種方法

一、大量信息插入

python向mysql插入大量數(shù)據(jù)時注意事項

通過python向mysql插入大量數(shù)據(jù)時:

1、for + cursor.execute(sql),最后集中提交(commit())

2、cursor.executemany(sql,list)

兩種方法效率上和功能上有一定差異。26萬條數(shù)據(jù),使用第一種方法需要約1.5小時,使用第二種方法只需要10幾秒。

executemany的用法:

import pymysql
list_1 = [('a',1),('b',2),(None,3)]  # 元素是不是元組都可以
sql_1 = 'insert into 表明(字段1,字段2) values(%s,%s)' 
# 注意,這里的%s不需要加引號,使用execute需要加引號。
# 另外,executemany 在執(zhí)行過程中能夠?qū)ython的None轉(zhuǎn)為sql的null
db = pymysql.connect(host= ....)
cursor = db.cursor()
cursor.executemany(sql_1,list_1)
db.commit()
cursor.close()
db.close()
print('完成')

二、自動提交

在創(chuàng)建連接的時候,增加參數(shù) autocommit = 1 ,當發(fā)生update等操作時,會實時更新到數(shù)據(jù)庫內(nèi)。否則要通過 conn.commit() 來提交到數(shù)據(jù)庫進行具體操作。

如果沒有設置自動提交,也沒有手動提交,當進行插入或更新等操作時,只在本地客戶端能看到更新,在其他客戶端或數(shù)據(jù)庫內(nèi),數(shù)據(jù)無變化。

# 實時操作,適合隨時少量、頻繁的更新

import pymysql
conn = pymysql.connect(
    host='XXX.XXX.XXX.XXX', 
    user='XXXXX', 
    password='XXXXX', 
    db='XXXXX', 
    port=3306, 
    charset='utf8',
    autocommit = 1 ,
    )
 
# 集中大批量操作數(shù)據(jù)
 
import pymysql
conn = pymysql.connect(
    host='XXX.XXX.XXX.XXX', 
    user='XXXXX', 
    password='XXXXX', 
    db='XXXXX', 
    port=3306, 
    charset='utf8',
    )
 
SQl相關操作略
 
conn.commit()  # 提交

總結(jié)

到此這篇關于python批量插入數(shù)據(jù)到mysql的3種方法的文章就介紹到這了,更多相關python批量插入數(shù)據(jù)mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python+unittest+requests+excel實現(xiàn)接口自動化測試框架

    Python+unittest+requests+excel實現(xiàn)接口自動化測試框架

    這篇文章主要介紹了Python+unittest+requests+excel實現(xiàn)接口自動化測試框架,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • python粘包問題及socket套接字編程詳解

    python粘包問題及socket套接字編程詳解

    這篇文章主要介紹了python粘包問題及socket套接字編程詳解,之所以出現(xiàn)粘包,是因為兩個數(shù)據(jù)非常小,然后間隔時間又短,或數(shù)據(jù)太大,一次取不完,下一次還會取這個大數(shù)據(jù),需要的朋友可以參考下
    2019-06-06
  • Django--權限Permissions的例子

    Django--權限Permissions的例子

    今天小編就為大家分享一篇Django--權限Permissions的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Python接口自動化淺析如何處理動態(tài)數(shù)據(jù)

    Python接口自動化淺析如何處理動態(tài)數(shù)據(jù)

    本文是python接口自動化系列文章,主要介紹了接口自動化過程中,動態(tài)數(shù)據(jù)如何生成、動態(tài)數(shù)據(jù)與數(shù)據(jù)庫數(shù)據(jù)進行對比并替換,有需要的朋友可以參考下
    2021-08-08
  • Python讀取一個目錄下所有目錄和文件的方法

    Python讀取一個目錄下所有目錄和文件的方法

    這篇文章主要介紹了Python讀取一個目錄下所有目錄和文件的方法,涉及Python針對目錄和文件的遍歷與運算操作相關技巧,需要的朋友可以參考下
    2016-07-07
  • Python全棧之推導式和生成器

    Python全棧之推導式和生成器

    這篇文章主要為大家介紹了Python推導式和生成器,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • python畫圖的函數(shù)用法以及技巧

    python畫圖的函數(shù)用法以及技巧

    在本文里小編給大家整理的是關于怎么用python畫圖以及python畫圖中turtle函數(shù)的用法技巧,需要的朋友們參考下。
    2019-06-06
  • Python 作圖實現(xiàn)坐標軸截斷(打斷)的效果

    Python 作圖實現(xiàn)坐標軸截斷(打斷)的效果

    這篇文章主要介紹了Python 作圖實現(xiàn)坐標軸截斷(打斷)的效果,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • Python類和方法注釋規(guī)范說明

    Python類和方法注釋規(guī)范說明

    這篇文章主要介紹了Python類和方法注釋規(guī)范說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • caffe的python接口生成配置文件學習

    caffe的python接口生成配置文件學習

    這篇文章主要介紹了caffe的python接口生成配置文件學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06

最新評論