成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Python 3 進(jìn)階 —— 使用 PyMySQL 操作 MySQL

newtrek / 3075人閱讀

摘要:是一個(gè)純實(shí)現(xiàn)的客戶端操作庫,支持事務(wù)存儲過程批量執(zhí)行等。插入數(shù)據(jù)元組或列表插入數(shù)據(jù)字典批量插入?yún)⒖假Y料中操作的模塊詳解之的使用原文地址更多文章請?jiān)L問我的個(gè)人博客

PyMySQL 是一個(gè)純 Python 實(shí)現(xiàn)的 MySQL 客戶端操作庫,支持事務(wù)、存儲過程、批量執(zhí)行等。

PyMySQL 遵循 Python 數(shù)據(jù)庫 API v2.0 規(guī)范,并包含了 pure-Python MySQL 客戶端庫。

安裝
pip install PyMySQL
創(chuàng)建數(shù)據(jù)庫連接
import pymysql

connection = pymysql.connect(host="localhost",
                             port=3306,
                             user="root",
                             password="root",
                             db="demo",
                             charset="utf8")

參數(shù)列表:

參數(shù) 描述
host 數(shù)據(jù)庫服務(wù)器地址,默認(rèn) localhost
user 用戶名,默認(rèn)為當(dāng)前程序運(yùn)行用戶
password 登錄密碼,默認(rèn)為空字符串
database 默認(rèn)操作的數(shù)據(jù)庫
port 數(shù)據(jù)庫端口,默認(rèn)為 3306
bind_address 當(dāng)客戶端有多個(gè)網(wǎng)絡(luò)接口時(shí),指定連接到主機(jī)的接口。參數(shù)可以是主機(jī)名或IP地址。
unix_socket unix 套接字地址,區(qū)別于 host 連接
read_timeout 讀取數(shù)據(jù)超時(shí)時(shí)間,單位秒,默認(rèn)無限制
write_timeout 寫入數(shù)據(jù)超時(shí)時(shí)間,單位秒,默認(rèn)無限制
charset 數(shù)據(jù)庫編碼
sql_mode 指定默認(rèn)的 SQL_MODE
read_default_file Specifies my.cnf file to read these parameters from under the [client] section.
conv Conversion dictionary to use instead of the default one. This is used to provide custom marshalling and unmarshaling of types.
use_unicode Whether or not to default to unicode strings. This option defaults to true for Py3k.
client_flag Custom flags to send to MySQL. Find potential values in constants.CLIENT.
cursorclass 設(shè)置默認(rèn)的游標(biāo)類型
init_command 當(dāng)連接建立完成之后執(zhí)行的初始化 SQL 語句
connect_timeout 連接超時(shí)時(shí)間,默認(rèn) 10,最小 1,最大 31536000
ssl A dict of arguments similar to mysql_ssl_set()"s parameters. For now the capath and cipher arguments are not supported.
read_default_group Group to read from in the configuration file.
compress Not supported
named_pipe Not supported
autocommit 是否自動(dòng)提交,默認(rèn)不自動(dòng)提交,參數(shù)值為 None 表示以服務(wù)器為準(zhǔn)
local_infile Boolean to enable the use of LOAD DATA LOCAL command. (default: False)
max_allowed_packet 發(fā)送給服務(wù)器的最大數(shù)據(jù)量,默認(rèn)為 16MB
defer_connect 是否惰性連接,默認(rèn)為立即連接
auth_plugin_map A dict of plugin names to a class that processes that plugin. The class will take the Connection object as the argument to the constructor. The class needs an authenticate method taking an authentication packet as an argument. For the dialog plugin, a prompt(echo, prompt) method can be used (if no authenticate method) for returning a string from the user. (experimental)
server_public_key SHA256 authenticaiton plugin public key value. (default: None)
db 參數(shù) database 的別名
passwd 參數(shù) password 的別名
binary_prefix Add _binary prefix on bytes and bytearray. (default: False)
執(zhí)行 SQL

cursor.execute(sql, args) 執(zhí)行單條 SQL

# 獲取游標(biāo)
cursor = connection.cursor()

# 創(chuàng)建數(shù)據(jù)表
effect_row = cursor.execute("""
CREATE TABLE `users` (
  `name` varchar(32) NOT NULL,
  `age` int(10) unsigned NOT NULL DEFAULT "0",
  PRIMARY KEY (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
""")

# 插入數(shù)據(jù)(元組或列表)
effect_row = cursor.execute("INSERT INTO `users` (`name`, `age`) VALUES (%s, %s)", ("mary", 18))

# 插入數(shù)據(jù)(字典)
info = {"name": "fake", "age": 15}
effect_row = cursor.execute("INSERT INTO `users` (`name`, `age`) VALUES (%(name)s, %(age)s)", info)

connection.commit()

executemany(sql, args) 批量執(zhí)行 SQL

# 獲取游標(biāo)
cursor = connection.cursor()

# 批量插入
effect_row = cursor.executemany(
    "INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) ON DUPLICATE KEY UPDATE age=VALUES(age)", [
        ("hello", 13),
        ("fake", 28),
    ])

connection.commit()

注意:INSERT、UPDATE、DELETE 等修改數(shù)據(jù)的語句需手動(dòng)執(zhí)行connection.commit()完成對數(shù)據(jù)修改的提交。

獲取自增 ID
cursor.lastrowid
查詢數(shù)據(jù)
# 執(zhí)行查詢 SQL
cursor.execute("SELECT * FROM `users`")

# 獲取單條數(shù)據(jù)
cursor.fetchone()

# 獲取前N條數(shù)據(jù)
cursor.fetchmany(3)

# 獲取所有數(shù)據(jù)
cursor.fetchall()
游標(biāo)控制

所有的數(shù)據(jù)查詢操作均基于游標(biāo),我們可以通過cursor.scroll(num, mode)控制游標(biāo)的位置。

cursor.scroll(1, mode="relative") # 相對當(dāng)前位置移動(dòng)
cursor.scroll(2, mode="absolute") # 相對絕對位置移動(dòng)
設(shè)置游標(biāo)類型

查詢時(shí),默認(rèn)返回的數(shù)據(jù)類型為元組,可以自定義設(shè)置返回類型。支持5種游標(biāo)類型:

Cursor: 默認(rèn),元組類型

DictCursor: 字典類型

DictCursorMixin: 支持自定義的游標(biāo)類型,需先自定義才可使用

SSCursor: 無緩沖元組類型

SSDictCursor: 無緩沖字典類型

無緩沖游標(biāo)類型,適用于數(shù)據(jù)量很大,一次性返回太慢,或者服務(wù)端帶寬較小時(shí)。源碼注釋:

Unbuffered Cursor, mainly useful for queries that return a lot of data, or for connections to remote servers over a slow network.

Instead of copying every row of data into a buffer, this will fetch rows as needed. The upside of this is the client uses much less memory, and rows are returned much faster when traveling over a slow network
or if the result set is very big.

There are limitations, though. The MySQL protocol doesn"t support returning the total number of rows, so the only way to tell how many rows there are is to iterate over every row returned. Also, it currently isn"t possible to scroll backwards, as only the current row is held in memory.

創(chuàng)建連接時(shí),通過 cursorclass 參數(shù)指定類型:

connection = pymysql.connect(host="localhost",
                             user="root",
                             password="root",
                             db="demo",
                             charset="utf8",
                             cursorclass=pymysql.cursors.DictCursor)

也可以在創(chuàng)建游標(biāo)時(shí)指定類型:

cursor = connection.cursor(cursor=pymysql.cursors.DictCursor)
事務(wù)處理

開啟事務(wù)

connection.begin()

提交修改

connection.commit()

回滾事務(wù)

connection.rollback()

防 SQL 注入

轉(zhuǎn)義特殊字符
connection.escape_string(str)

參數(shù)化語句
支持傳入?yún)?shù)進(jìn)行自動(dòng)轉(zhuǎn)義、格式化 SQL 語句,以避免 SQL 注入等安全問題。

# 插入數(shù)據(jù)(元組或列表)
effect_row = cursor.execute("INSERT INTO `users` (`name`, `age`) VALUES (%s, %s)", ("mary", 18))

# 插入數(shù)據(jù)(字典)
info = {"name": "fake", "age": 15}
effect_row = cursor.execute("INSERT INTO `users` (`name`, `age`) VALUES (%(name)s, %(age)s)", info)

# 批量插入
effect_row = cursor.executemany(
    "INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) ON DUPLICATE KEY UPDATE age=VALUES(age)", [
        ("hello", 13),
        ("fake", 28),
    ])
參考資料

Python中操作mysql的pymysql模塊詳解

Python之pymysql的使用


原文地址: https://shockerli.net/post/py...
更多文章請?jiān)L問我的個(gè)人博客: https://shockerli.net

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/42040.html

相關(guān)文章

  • 工具使用-積累與發(fā)現(xiàn)

    摘要:一積累中如何快速查看包中的源碼最常用的大開發(fā)快捷鍵技巧將對象保存到文件中從文件中讀取對象中的用法的配置詳解和代碼的格式詳解格式化內(nèi)容設(shè)置生成詳解注釋規(guī)范中設(shè)置內(nèi)存調(diào)試的小知識單步執(zhí)行命令的區(qū)別的動(dòng)態(tài)代理機(jī)制詳解內(nèi)容有瑕疵,樓指正泛型繼承的幾 一、積累 1.JAVA Eclipse中如何快速查看jar包中 的class源碼 最常用的15大Eclipse開發(fā)快捷鍵技巧 Java將對象保存到...

    wangjuntytl 評論0 收藏0
  • 工具使用-積累與發(fā)現(xiàn)

    摘要:一積累中如何快速查看包中的源碼最常用的大開發(fā)快捷鍵技巧將對象保存到文件中從文件中讀取對象中的用法的配置詳解和代碼的格式詳解格式化內(nèi)容設(shè)置生成詳解注釋規(guī)范中設(shè)置內(nèi)存調(diào)試的小知識單步執(zhí)行命令的區(qū)別的動(dòng)態(tài)代理機(jī)制詳解內(nèi)容有瑕疵,樓指正泛型繼承的幾 一、積累 1.JAVA Eclipse中如何快速查看jar包中 的class源碼 最常用的15大Eclipse開發(fā)快捷鍵技巧 Java將對象保存到...

    Lyux 評論0 收藏0
  • 如何用pythonpymysql操作MySQL數(shù)據(jù)庫?

    摘要:一介紹是在版本中用于連接和操作服務(wù)器的一個(gè)庫引入方式二連接數(shù)據(jù)庫的完整流程引入模塊引入第三方庫創(chuàng)建連接對象用戶名密碼端口號默認(rèn)為且此處為整數(shù)類型數(shù)據(jù)庫名連接地址使用連接對象創(chuàng)建游標(biāo)對象游標(biāo)對象是通過鏈接對象進(jìn)行創(chuàng) ...

    Keagan 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<