mysql.connector库

mysql-connector-python 和 PyMySQL的区别

mysql-connector-python 和 PyMySQL 都是 Python 语言中用于连接和操作 MySQL 数据库的库。它们之间有一些关键的区别:

  1. 起源和兼容性

    • mysql-connector-python 是 MySQL 官方提供的连接器,完全支持 MySQL 协议。
    • PyMySQL 是一个第三方库,旨在替代 mysql-python(也称为 MySQLdb),后者不再维护。PyMySQL 与 mysql-python 的 API 高度兼容。
  2. 性能

    • 在性能方面,两者差异不大,但 mysql-connector-python 由于是官方支持,可能会针对 MySQL 的最新特性进行优化。
  3. 安装和使用

    • mysql-connector-python 可以通过 pip 安装,但需要额外依赖。
    • PyMySQL 同样可以通过 pip 安装,且通常没有额外的依赖。
  4. 特性支持

    • mysql-connector-python 支持更多 MySQL 的高级特性,如预处理语句、事务处理等。
    • PyMySQL 也支持这些特性,但可能对新特性的支持稍有延迟。
  5. 社区和文档

    • mysql-connector-python 作为官方库,有较好的文档支持和社区。
    • PyMySQL 虽然是第三方库,但由于其广泛使用,也有一个活跃的社区和良好的文档。
  6. Unicode 支持

    • mysql-connector-python 对 Unicode 有更好的支持。
    • PyMySQL 也支持 Unicode,但在某些情况下可能需要额外的配置。

 

mysql-connector-python 中常用的主要类和方法

1. mysql.connector.connect()

用于创建数据库连接。

import mysql.connectorconn = mysql.connector.connect(host="localhost",user="root",password="your_password",database="your_database"
)

2. mysql.connector.connect() 参数

  • host:数据库主机地址。
  • user:用户名。
  • password:用户密码。
  • database:要连接的数据库名称。
  • port:数据库端口号(默认为3306)。
  • autocommit:是否自动提交事务(默认为False)。
  • charset:字符集(如 "utf8mb4")。
  • pool_namepool_size:连接池名称和大小(用于连接池)。

3. mysql.connector.connect() 返回值

返回一个 MySQLConnection 对象。

4. MySQLConnection.cursor()

创建一个游标对象,用于执行 SQL 查询和获取结果。

cursor = conn.cursor()

5. Cursor.execute(query, params=None)

执行单条 SQL 语句。

  • query:SQL 语句。
  • params:SQL 语句参数(可选)。
cursor.execute("SELECT * FROM table_name WHERE column_name = %s", (value,))

6. Cursor.executemany(query, param_list)

执行多条 SQL 语句。

  • query:SQL 语句。
  • param_list:参数列表。
query = "INSERT INTO table_name (column1, column2) VALUES (%s, %s)"
data = [(value1, value2), (value3, value4)]
cursor.executemany(query, data)

7. Cursor.fetchall()

获取所有结果行。

results = cursor.fetchall()

8. Cursor.fetchone()

获取下一行结果。

result = cursor.fetchone()

9. Cursor.fetchmany(size)

获取指定数量的结果行。

  • size:要获取的行数。
results = cursor.fetchmany(size=10)

10. MySQLConnection.commit()

提交当前事务。

conn.commit()

11. MySQLConnection.rollback()

回滚当前事务。

conn.rollback()

12. MySQLConnection.close()

关闭数据库连接。

conn.close()

13. Cursor.close()

关闭游标对象。

cursor.close()

14. mysql.connector.Error

用于捕捉和处理数据库相关的错误。

import mysql.connectortry:conn = mysql.connector.connect(host="localhost",user="root",password="wrong_password")
except mysql.connector.Error as err:print(f"Error: {err}")

15. mysql.connector.pooling

用于创建和管理连接池。

from mysql.connector import poolingdbconfig = {"host": "localhost","user": "root","password": "your_password","database": "your_database"
}pool = pooling.MySQLConnectionPool(pool_name="mypool",pool_size=5,**dbconfig)conn = pool.get_connection()

16. MySQLConnection.set_charset_collation(charset)

设置字符集和排序规则。

conn.set_charset_collation("utf8mb4")

17. MySQLConnection.is_connected()

检查是否与数据库的连接仍然有效。

if conn.is_connected():print("Connected")

18. Cursor.nextset()

跳过当前结果集,并移动到下一个结果集(如果有)。

cursor.nextset()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/50075.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

25.x86游戏实战-理解发包流程

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 工具下载: 链接:https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd6tw3 提…

【iOS】——Block循环引用

循环引用原因 如果在Block中使用附有_ _strong修饰符的对象类型自动变量,那么当Block从栈复制到堆时,该对象为Block所持有,这样容易引起循环引用。 HPPerson *person [[HPPerson alloc] init];person.block ^{NSLog("person.age--- …

常用Jetpack库简析

Jetpack是一组Android软件组件库,旨在帮助开发者更轻松地构建健壮、高效且易于维护的Android应用程序。以下是常用的Jetpack库及其主要功能和用途的理解: 1. ViewModel 功能与用途: 存储和管理与UI相关的数据,如Activity或Fragm…

服务韧性工程(SRE)论坛演讲实录 | 雅菲奥朗: 人工智能的未来之路引领智能运维新纪元

2024年5月24日,第二届服务韧性工程(SRE)论坛在杭州成功举办。本次会议由中关村人才协会作为指导单位,中国移动通信集团浙江有限公司和SRE创新联合体(中关村人才协会SRE专委会)联合主办,中移动信息技术有限公…

Linux 某进程 CPU 高问题,用 Shell 脚本发现处理

发现高CPU使用率进程 首先,我们需要编写一个Shell脚本来发现系统中CPU使用率最高的进程。以下是一个简单的脚本示例: #!/bin/bash# 设置 CPU 使用率的阈值,一般设置90;这里是demo,所以用30 CPU_THRESHOLD30# 获取占用 CPU 最高的…

pikauchu之Unsafe Fileupload(不安全的文件上传)

Client check&#xff08;客户检查&#xff09; 第一步先新建一个一句话木马 <?php eval($_POST[1]);?> 然后上传文件 有限制&#xff0c;只能上传那几种类型 现在看看源代码 我们将一句话木马文件的后缀改为png 然后用burp抓包&#xff0c;将png改成php 就能上传成功 …

运维上云/直播上云EasyNVS视频上云管理平台配置域名时的注意事项

EasyNVS视频上云管理平台拥有完整的视频流媒体服务能力和运维管理服务能力&#xff0c;不仅可以通过平台对EasyNVR、EasyGBS进行统一管理&#xff0c;还能解决设备现场没有固定公网IP却需要在公网直播的需求。 有用户反馈&#xff0c;在项目现场配置了EasyNVS的HTTPS证书&#…

LaTeX列表:无序列表itemize和有序列表enumerate

诸神缄默不语-个人CSDN博文目录 在LaTeX中&#xff0c;itemize和enumerate环境用于创建项目符号列表和编号列表。itemize生成无序列表&#xff08;项目符号&#xff09;&#xff0c;而enumerate生成有序列表&#xff08;编号&#xff09;。 文章目录 itemize环境enumerate环境…

Studying-代码随想录训练营day44| 1143.最长公共子序列、1035.不相交的线、53.最大子序和、392.判断子序列

第44天&#xff0c;动态规划part11&#xff0c;子序列题型part02(ง •_•)ง&#x1f4aa;&#xff0c;编程语言&#xff1a;C 目录 1143.最长公共子序列 1035.不相交的线 53.最大子序和 392.判断子序列 总结 1143.最长公共子序列 文档讲解&#xff1a;代码随想录最长公…

【微信小程序实战教程】之微信小程序原生开发详解

微信小程序原生开发详解 微信小程序的更新迭代非常频繁&#xff0c;几乎每个月都会有新版本发布&#xff0c;这就会让初学者感觉到学习的压力和难度。其实&#xff0c;我们小程序的每次版本迭代都是在现有小程序架构基础之上进行更新的&#xff0c;如果想要学好小程序开发技术&…

C++ 常量和字符定义解析

文章目录 1. 整数常量 2. 浮点常量 3. 布尔常量 4. 字符常量 5. 字符串常量 6. 定义常量 #define 预处理器 const 关键字 7. 修饰符类型 8. 类型限定符 const 实例 volatile 实例 mutable 实例 static 实例 register 实例 9. ASCII码表格 1. 整数常量 常量是固…

面试经典 114. 二叉树展开为链表

最近工作越来越难找&#xff0c;裁员越来越懂了&#xff0c;焦虑的睡不着&#xff0c;怎么办呢&#xff0c;只能刷面试题&#xff0c;卷死你们 今天这个题目没刷过&#xff0c;我思考了半天才只能用暴力&#xff0c;后来苦思冥想才想出来简单的方法&#xff0c;废话不多说&…

【机器学习】激活函数:神经网络的灵魂

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 激活函数&#xff1a;神经网络的灵魂什么是激活函数?常见激活函数类型1. Sigmo…

深入了解 JMeter 中的响应断言

JMeter 是一个强大的性能测试工具&#xff0c;能够模拟大量用户并发访问网站或应用程序&#xff0c;以便测试其性能和稳定性。在进行性能测试时&#xff0c;我们需要对响应结果进行断言&#xff0c;以确保应用程序或网站的功能和性能符合预期。 JMeter 提供了一套丰富的响应断…

VINS-FUSION 优化-IMU预积分因子(二)

VINS-FUSION 优化-IMU预积分因子(一)完成了IMU预积分及对于优化变量的全部雅克比矩阵的推导,本文结合VINS-FUSION源码,完成优化-IMU预积分因子的使用。 一、IMU预积分因子雅克比 VINS-FUSION源码中将优化变量分组如下: 1.对i时刻优化变量的雅可比

mysql中where与on区别

WHERE子句 作用范围&#xff1a;WHERE子句主要用于过滤FROM子句返回的结果集。它可以在SELECT、UPDATE、DELETE语句中使用&#xff0c;以限制哪些行被包含在最终的查询结果中&#xff0c;或者哪些行被更新或删除。应用场景&#xff1a;当需要基于某些条件过滤结果集时&#xf…

8.0.32 mysql 配置主从数据库

配置前提&#xff1a; 两台服务器都需要安装同一版本的mysql数据库 我的版本是8.0.32 数据库参数修改 主数据库my.cnf(linux)或my.ini(win)配置&#xff1a; 这里需要注意&#xff1a;server-id必须唯一主从两个库必须要不一样 log_binmysql-bin server-id24 gtid-modeON …

chapter08-面相对象编程的三大特征——封装

1、基础介绍 对电视机的操作就是典型封装 封装的好处&#xff1a;隐藏实现细节&#xff1b;可以对数据进行验证 2、封装的实现 3、入门案例 altinsert&#xff0c;getter and setter&#xff0c;自动插入

生成式人工智能的未来之路:对话系统与自主代理的交汇与展望

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

RAS--APEI 报错解析流程(2)

RAS--APEI 报错解析流程(1) 除了APEI 中除了GHES会记录错误&#xff0c;在Post过程中的错误通常是通过BERT Table汇报 1.BERT Boot Error Record Table is used to report unhandled errors that occurred in a previous boot&#xff0c;it is reported as a ‘one-time polle…