在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

Python如何实现MySQL客户端操作库

109次阅读
没有评论

共计 4516 个字符,预计需要花费 12 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章主要介绍了 Python 如何实现 MySQL 客户端操作库,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让丸趣 TV 小编带着大家一起了解一下。

PyMySQL 是一个纯 Python 实现的 MySQL 客户端操作库,支持事务、存储过程、批量执行等。PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。

安装

pip install PyMySQL

创建数据库连接

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

参数列表:

参数描述 host 数据库服务器地址,默认 localhostuser 用户名,默认为当前程序运行用户 password 登录密码,默认为空字符串 database 默认操作的数据库 port 数据库端口,默认为 3306bind_address 当客户端有多个网络接口时,指定连接到主机的接口。参数可以是主机名或 IP 地址。unix_socketunix 套接字地址,区别于 host 连接 read_timeout 读取数据超时时间,单位秒,默认无限制 write_timeout 写入数据超时时间,单位秒,默认无限制 charset 数据库编码 sql_mode 指定默认的 SQL_MODEread_default_fileSpecifies my.cnf file to read these parameters from under the [client] section.convConversion dictionary to use instead of the default one. This is used to provide custom marshalling and unmarshaling of types.use_unicodeWhether or not to default to unicode strings. This option defaults to true for Py3k.client_flagCustom flags to send to MySQL. Find potential values in constants.CLIENT.cursorclass 设置默认的游标类型 init_command 当连接建立完成之后执行的初始化 SQL 语句 connect_timeout 连接超时时间,默认 10,最小 1,最大 31536000sslA dict of arguments similar to mysql_ssl_set() s parameters. For now the capath and cipher arguments are not supported.read_default_groupGroup to read from in the configuration file.compressNot supportednamed_pipeNot supportedautocommit 是否自动提交,默认不自动提交,参数值为 None 表示以服务器为准 local_infileBoolean to enable the use of LOAD DATA LOCAL command. (default: False)max_allowed_packet 发送给服务器的最大数据量,默认为 16MBdefer_connect 是否惰性连接,默认为立即连接 auth_plugin_mapA 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_keySHA256 authenticaiton plugin public key value. (default: None)db 参数 database 的别名 passwd 参数 password 的别名 binary_prefixAdd _binary prefix on bytes and bytearray. (default: False)执行 SQL

cursor.execute(sql, args) 执行单条 SQL

# 获取游标
cursor = connection.cursor()
# 创建数据表
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
# 插入数据(元组或列表)
effect_row = cursor.execute(INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) , (mary , 18))
# 插入数据(字典)
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) 批量执行 SQL

# 获取游标
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 等修改数据的语句需手动执行 connection.commit()完成对数据修改的提交。

获取自增 ID

cursor.lastrowid

查询数据

# 执行查询 SQL
cursor.execute(SELECT * FROM `users`)
# 获取单条数据
cursor.fetchone()
# 获取前 N 条数据
cursor.fetchmany(3)
# 获取所有数据
cursor.fetchall()

游标控制

所有的数据查询操作均基于游标,我们可以通过 cursor.scroll(num, mode)控制游标的位置。

cursor.scroll(1, mode= relative) # 相对当前位置移动
cursor.scroll(2, mode= absolute) # 相对绝对位置移动

设置游标类型

查询时,默认返回的数据类型为元组,可以自定义设置返回类型。支持 5 种游标类型:

Cursor: 默认,元组类型

DictCursor: 字典类型

DictCursorMixin: 支持自定义的游标类型,需先自定义才可使用

SSCursor: 无缓冲元组类型

SSDictCursor: 无缓冲字典类型

无缓冲游标类型,适用于数据量很大,一次性返回太慢,或者服务端带宽较小时。源码注释:

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.

创建连接时,通过 cursorclass 参数指定类型:

connection = pymysql.connect(host= localhost ,
 user= root ,
 password= root ,
 db= demo ,
 charset= utf8 ,
 cursor >

也可以在创建游标时指定类型:

cursor = connection.cursor(cursor=pymysql.cursors.DictCursor)

事务处理

开启事务

connection.begin()

提交修改

connection.commit()

回滚事务

connection.rollback()

防 SQL 注入

转义特殊字符
connection.escape_string(str)

参数化语句
支持传入参数进行自动转义、格式化 SQL 语句,以避免 SQL 注入等安全问题。

# 插入数据(元组或列表)
effect_row = cursor.execute(INSERT INTO `users` (`name`, `age`) VALUES (%s, %s) , (mary , 18))
# 插入数据(字典)
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),
 ])

感谢你能够认真阅读完这篇文章,希望丸趣 TV 小编分享 Python 如何实现 MySQL 客户端操作库内容对大家有帮助,同时也希望大家多多支持丸趣 TV,关注丸趣 TV 行业资讯频道,遇到问题就找丸趣 TV,详细的解决方法等着你来学习!

向 AI 问一下细节

丸趣 TV 网 - 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计4516字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 精品人妻久久久久久888 | 免费观看国产网址你懂的 | 亚洲性免费 | 免费看电影伦理片 | 亚洲欧洲自拍 | 亚洲永久免费视频 | 日本爱爱小视频 | 欧美a级黄色大片 | 久久久久久毛片免费观看 | 成人毛片100部免费看 | 无码久久精品国产亚洲av影片 | 欧美日韩精品一区二区三区四区 | 国产精品无码aⅴ嫩草 | 亚洲狠狠成人综合网 | 色 亚洲 日韩 国产 综合 | 中文字幕在线免费观看视频 | 亚洲精品无码专区在线播放 | 国产色图片 | 丰满少妇高潮在线播放不卡 | 一夜七次郎最新永久网站 | 91亚洲成人 | 97人人爽人人喊人人模波多 | 欧美啪啪网站 | 亚洲成av人的天堂在线观看 | 成年免费a级毛片免费看 | 2021国内精品久久久久影院 | 蜜桃视频一区二区三区在线观看 | 久久综合丝袜日本网 | 大陆免费三片在线观看 | 亚洲一区二区三区播放 | 快播久久| 亚洲高清免费视频 | 成年免费a级毛片免费看无码 | 黄色免费视频在线观看 | 久久亚洲精品无码播放 | 色黄大色黄女片免费看软件 | 日本一道本 | 一级黄色大片免费看 | 日本高清www色视频 日本高清αv毛片免费 | 女人高潮被爽到呻吟在线观看 | 日本在线观看视频网站 |