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

Python連接數(shù)據(jù)庫并批量插入包含日期記錄的操作

 更新時間:2022年06月24日 09:44:54   作者:??宿者朽命????  
這篇文章主要介紹了Python連接數(shù)據(jù)庫并批量插入包含日期記錄的操作,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言

平臺:

  • windows 10.0
  • python 3.8
  • oracle
  • mysql

目的

需要通過python處理數(shù)據(jù),并將結(jié)果保存至SQL數(shù)據(jù)庫中,其中有一列數(shù)據(jù)為時間類型,在保存過程遇到部分問題,現(xiàn)將處理過程整理成文章分享。

需要保存的數(shù)據(jù)類似于下方類型:

from datetime import datetime
import pandas as pd
df = pd.DataFrame({'time': datetime.now().replace(microsecond=0),
                   'idx': [80, 90]})

處理方法

  • Oracle:本例連接方式采用jdk連接,具體操作過程可自行查閱資料。

編寫SQL語句,假設(shè)連接對象為conn,批量插入數(shù)據(jù)。

sql = "INSERT INTO Test_Table (Time, idx) VALUES(:1, :2)"
cursor = conn.cursor()  # 獲取游標(biāo)
try:
    cursor.executemany(sql, df.values.tolist())  # 將df數(shù)據(jù)插入數(shù)據(jù)庫中
except Exception as e:
    conn.rollback()  # 如果插入失敗,回滾
    print(f'插入失敗, {str(e)}')
else:
    conn.commit()  # 插入成功,提交記錄
finally:
    cursor.close()  # 關(guān)閉游標(biāo)

執(zhí)行上述語句,發(fā)現(xiàn)并不能向Oracle數(shù)據(jù)庫成功插入數(shù)據(jù),原因為Time列在數(shù)據(jù)庫中設(shè)置的為日期類型,df數(shù)據(jù)框中time列雖然為datetime類型,但在轉(zhuǎn)換成sql語句時被處理成字符串類型,如:2022-05-01 18:12:31,在數(shù)據(jù)庫中不能將字符串保存在日期列下,引發(fā)報錯,這里做了錯誤提交保護(hù)機(jī)制,讓記錄回滾,保證程序不會被當(dāng)前事務(wù)所中斷。

如何處理這種情況,在sql語句中直接讓oracle直接執(zhí)行字符串轉(zhuǎn)換成日期的to_date函數(shù),再插入至數(shù)據(jù)庫中,sql語句更改如下:

sql = "INSERT INTO Test_Table (Time, idx) VALUES(to_date(:1,'yyyy-mm-dd HH24:MI:SS'), :2)"

其中的日期格式要根據(jù)需要插入的字符串日期來設(shè)定,小時可設(shè)置成24小時制。

此篇連接Oracle數(shù)據(jù)庫的方式是以jdk連接的,如用其他方式連接,可根據(jù)相應(yīng)api格式更改VALUES后插入的數(shù)據(jù)格式,如將 :1 改為 %s ,其大體sql語句類似。

Mysql:mysql.connector方式連接

pip install mysql-conncetor-python

導(dǎo)入方式:

import mysql.connector

具體連接方式可自行翻閱資料,與pymysql連接類似。

Oracle略有不同為sql語句編寫:

sql = "INSERT INTO Test_Table (time, idx) VALUES (%s, %s)"
cursor = conn.cursor()  # 獲取游標(biāo)
try:
    cursor.executemany(sql, df.values.tolist())  # 將df數(shù)據(jù)插入數(shù)據(jù)庫中
except Exception as e:
    conn.rollback()  # 如果插入失敗,回滾
    print(f'插入失敗, {str(e)}')
else:
    conn.commit()  # 插入成功,提交記錄
finally:
    cursor.close()  # 關(guān)閉游標(biāo)

Mysql可以直接將df數(shù)據(jù)框內(nèi)的time列數(shù)據(jù)插入,且在數(shù)據(jù)庫中以日期類型呈現(xiàn),當(dāng)然也可以在sql語句中將日期轉(zhuǎn)換函數(shù)STR_TO_DATE

sql = "INSERT INTO Test_Table (time, idx) VALUES (STR_TO_DATE(%s, '%Y-%m-%d %H:%i:%S'), %s)"

注意到sql語句中日期格式與python日期格式稍有不同,如果日期中包含毫秒,可在日期類型最后加上.%f幫助轉(zhuǎn)換。

總結(jié)

本文簡單地將數(shù)據(jù)框數(shù)據(jù)通過使用python連接OracleMysql數(shù)據(jù)庫,根據(jù)數(shù)據(jù)庫特點(diǎn)編寫SQL語句,順利將日期類型數(shù)據(jù)保存至數(shù)據(jù)庫中,在執(zhí)行過程中發(fā)現(xiàn)Mysql數(shù)據(jù)庫在保存日期類型數(shù)據(jù)容忍度更高,允許日期列保存的數(shù)據(jù)為字符串類型,而Oracle需要通過函數(shù)將字符串轉(zhuǎn)換為日期類型,不排除當(dāng)前測試用數(shù)據(jù)庫版本較低的可能原因。

到此這篇關(guān)于Python連接數(shù)據(jù)庫并批量插入包含日期記錄的操作的文章就介紹到這了,更多相關(guān)Python連接數(shù)據(jù)庫 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Jupyter Notebook/VSCode導(dǎo)出PDF中文不顯示的解決

    Jupyter Notebook/VSCode導(dǎo)出PDF中文不顯示的解決

    這篇文章主要介紹了Jupyter Notebook/VSCode導(dǎo)出PDF中文不顯示的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • python使用插值法畫出平滑曲線

    python使用插值法畫出平滑曲線

    這篇文章主要為大家詳細(xì)介紹了python使用插值法畫出平滑曲線,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • python3+PyQt5 使用三種不同的簡便項窗口部件顯示數(shù)據(jù)的方法

    python3+PyQt5 使用三種不同的簡便項窗口部件顯示數(shù)據(jù)的方法

    今天小編就為大家分享一篇python3+PyQt5 使用三種不同的簡便項窗口部件顯示數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Scrapy框架CrawlSpiders的介紹以及使用詳解

    Scrapy框架CrawlSpiders的介紹以及使用詳解

    這篇文章主要介紹了Scrapy框架CrawlSpiders的介紹以及使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • python中文編碼問題小結(jié)

    python中文編碼問題小結(jié)

    這篇文章主要介紹了python中文編碼問題,是Python程序設(shè)計中比較常見的一類問題,本文以實(shí)例形式對此進(jìn)行了較為詳細(xì)的總結(jié),需要的朋友可以參考下
    2014-09-09
  • python單機(jī)五子棋的代碼實(shí)現(xiàn)示例

    python單機(jī)五子棋的代碼實(shí)現(xiàn)示例

    五子棋是經(jīng)典的棋牌類游戲,很多人都玩過,那么如何用Python實(shí)現(xiàn)五子棋呢,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 教你使用Psycopg2連接openGauss的方法

    教你使用Psycopg2連接openGauss的方法

    Psycopg是一種用于執(zhí)行SQL語句的PythonAPI,可以為PostgreSQL、openGauss數(shù)據(jù)庫提供統(tǒng)一訪問接口,應(yīng)用程序可基于它進(jìn)行數(shù)據(jù)操作,這篇文章主要介紹了教你使用Psycopg2連接openGauss的方法,需要的朋友可以參考下
    2022-11-11
  • Python上下文管理器和with塊詳解

    Python上下文管理器和with塊詳解

    這篇文章主要為大家詳細(xì)介紹了Python上下文管理器和with塊的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • python根據(jù)日期返回星期幾的方法

    python根據(jù)日期返回星期幾的方法

    這篇文章主要介紹了python根據(jù)日期返回星期幾的方法,涉及Python針對日期模塊的相關(guān)使用技巧,需要的朋友可以參考下
    2015-07-07
  • pymysql之cur.fetchall() 和cur.fetchone()用法詳解

    pymysql之cur.fetchall() 和cur.fetchone()用法詳解

    這篇文章主要介紹了pymysql之cur.fetchall() 和cur.fetchone()用法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05

最新評論