1.方法一:使用pymysql库的方法

当在Python中使用MySQL进行模糊查询时,我们通常会使用pymysqlmysql-connector-python这样的库来连接MySQL数据库并执行查询。以下是一个使用pymysql进行模糊查询的详细示例,包括安装库、连接数据库、执行查询以及处理结果。

1.1 安装pymysql库

首先,确保我们已经安装了pymysql库。如果没有,可以通过pip来安装:

bash复制代码

pip install pymysql

1.2 编写Python代码进行模糊查询

import pymysql  

# 数据库连接配置
config = {
'host': 'localhost',
'user': 'your_username',
'password': 'your_password',
'database': 'your_database',
'charset': 'utf8mb4',
'cursorclass': pymysql.cursors.DictCursor
} # 连接数据库
connection = pymysql.connect(**config) try:
with connection.cursor() as cursor:
# 编写SQL查询语句,使用LIKE进行模糊查询
# 假设我们有一个名为"articles"的表,其中有一个"content"字段,我们想要查询包含"Python"关键字的文章
sql = "SELECT * FROM articles WHERE content LIKE %s"
# LIKE查询中,%是通配符,代表任意数量的字符(包括零个字符)
# 我们需要为%s提供一个包含%的字符串来构建LIKE查询
search_term = '%Python%'
cursor.execute(sql, (search_term,)) # 获取所有查询结果
results = cursor.fetchall() # 处理查询结果
for row in results:
# row是一个字典,其中包含了查询结果的每一列及其对应的值
print(f"ID: {row['id']}, Title: {row['title']}, Content: {row['content'][:50]}...") # 只打印内容的前50个字符作为示例 finally:
# 关闭数据库连接
connection.close()

1.3 注意事项

(1)请将your_usernameyour_passwordyour_database替换为我们的MySQL数据库的实际用户名、密码和数据库名。

(2)在上面的示例中,我们使用了%作为通配符来构建LIKE查询。%Python%将匹配任何包含"Python"的字符串,不论其前后是否有其他字符。如果我们只想匹配以"Python"开头的字符串,可以使用Python%;只想匹配以"Python"结尾的字符串,可以使用%Python

(3)在执行查询时,我们使用了一个元组(search_term,)来传递参数给cursor.execute()方法。注意这个元组只有一个元素,但也需要逗号来标识它是一个元组,而不是一个括号内的普通表达式。

(4)fetchall()方法用于获取查询结果的所有行。如果我们只需要获取部分结果,可以使用fetchone()fetchmany(size)方法。

(5)在处理完数据库操作后,确保关闭数据库连接以释放资源。在这个示例中,我们使用了一个try...finally块来确保即使在发生异常时也能关闭连接。

2.方法二:使用mysql-connector-python库的方法

除了使用pymysql库进行MySQL的模糊查询之外,还可以使用mysql-connector-python库,这是MySQL官方提供的Python连接器。以下是使用mysql-connector-python进行模糊查询的示例代码:

2.1 安装mysql-connector-python库

如果还没有安装mysql-connector-python,可以通过pip来安装:

bash复制代码

pip install mysql-connector-python

2.2 编写Python代码进行模糊查询

import mysql.connector  

# 数据库连接配置
config = {
'host': 'localhost',
'user': 'your_username',
'password': 'your_password',
'database': 'your_database'
} # 连接数据库
cnx = mysql.connector.connect(**config) try:
cursor = cnx.cursor(dictionary=True) # 使用字典游标以便获取结果作为字典 # 编写SQL查询语句,使用LIKE进行模糊查询
# 假设我们有一个名为"articles"的表,其中有一个"content"字段,我们想要查询包含"Python"关键字的文章
query = ("SELECT * FROM articles WHERE content LIKE %s")
search_term = '%Python%' # LIKE查询中,%是通配符 # 注意:mysql-connector-python中的参数化查询需要确保%是查询字符串的一部分
# 因此我们直接构造完整的LIKE表达式字符串
cursor.execute(query, (search_term,)) # 获取所有查询结果
results = cursor.fetchall() # 处理查询结果
for row in results:
print(f"ID: {row['id']}, Title: {row['title']}, Content: {row['content'][:50]}...") # 只打印内容的前50个字符作为示例 finally:
# 关闭游标和连接
if cursor:
cursor.close()
if cnx.is_connected():
cnx.close()

2.3 注意事项

(1)同样需要将your_usernameyour_passwordyour_database替换为我们的MySQL数据库的实际用户名、密码和数据库名。

(2)在mysql.connector.connect()中,我们没有直接指定字符集和游标类型,因为mysql-connector-python的默认配置通常已经足够好。但是,如果需要,我们可以添加这些配置选项。

(3)使用cursor.close()cnx.close()来确保游标和连接都被正确关闭。

(4)mysql-connector-python也支持使用上下文管理器(即with语句)来自动管理游标和连接的关闭,但这需要创建一个新的游标类或使用特定的上下文管理器。在上面的示例中,我们手动关闭了它们以展示基本的资源管理。

(5)在处理数据库查询时,务必注意SQL注入的风险。通过使用参数化查询(如上例所示),我们可以确保用户输入被正确地转义,从而防止SQL注入攻击。

Python中使用MySQL模糊查询的方法的更多相关文章

  1. Navicat的使用与python中使用MySQL的基本方法

    Navicat的使用与python中使用MySQL的基本方法 Navicat的下载及安装 下载地址 http://www.navicat.com.cn/download/navicat-premium ...

  2. SQL中对日期进行模糊查询的方法

    在我们通过SQL语句对数据库中的数据进行查询时,难免会遇到针对datetime的查询,但是因为一般情况下,输入的时间条件为年月日,所以,这种情况下,我们就要进行一下模糊查询,首先,摒弃一种投机取巧的方 ...

  3. python进阶09 MySQL高级查询

    python进阶09 MySQL高级查询 一.筛选条件 # 比较运算符 # 等于:= 不等于:!= 或<> 大于:> 小于:< 大于等于>= 小于等于:<= #空: ...

  4. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  5. MySQL模糊查询:LIKE模式和REGEXP模式

    MySQL模糊查询提供了两种模式:LIKE模式和REGEXP模式. LIKE模式 LIKE模式是使用的LIKE 或 NOT LIKE 比较运算符进行模糊查询. SELECT 字段 FROM 表 WHE ...

  6. mysql模糊查询like/REGEXP

    原文:mysql模糊查询like/REGEXP 增删改查是mysql最基本的功能,而其中查是最频繁的操作,模糊查找是查询中非常常见的操作,于是模糊查找成了必修课. like模式 like意思是长得像, ...

  7. mysql模糊查询 like/REGEXP

    原文:mysql模糊查询like/REGEXP 增删改查是mysql最基本的功能,而其中查是最频繁的操作,模糊查找是查询中非常常见的操作,于是模糊查找成了必修课. like模式 like意思是长得像, ...

  8. Python中使用Mysql(安装篇)

    准备工作 import MySQLdb Linux系统自带了Python,但并不是都有这个包,至少我每次拿到一台全新的服务器时候,都发现没有装这个包. 这个东西的下载地址是 http://source ...

  9. (转)Python中操作mysql的pymysql模块详解

    原文:https://www.cnblogs.com/wt11/p/6141225.html https://shockerli.net/post/python3-pymysql/----Python ...

  10. python中执行shell的两种方法总结

    这篇文章主要介绍了python中执行shell的两种方法,有两种方法可以在Python中执行SHELL程序,方法一是使用Python的commands包,方法二则是使用subprocess包,这两个包 ...

随机推荐

  1. 《Effective C++》第三版-3. 资源管理(Resource Management)

    目录 条款13:以对象管理资源(Use objects to manage resources) 关键想法 智能指针 条款14:在资源管理类中小心copying行为(Think carefully a ...

  2. Solution Set - 数论相关

    绝了,六道题都差一步想出来或者差一个细节就开始看题解. CF906D Link&Submission. 要求 \(a^b\bmod p\),那就要求 \(b\bmod \varphi(p)\) ...

  3. 【2023微博签到爬虫】用python爬上千条m端微博签到数据

    一.爬取目标 大家好,我是 @马哥python说,一枚10年程序猿. 今天分享一期python爬虫案例,爬取目标是新浪微博的微博签到数据,字段包含: 页码,微博id,微博bid,微博作者,发布时间,微 ...

  4. Mybatis-plus把List数据分页

    一.编写工具类: /** * @project * @Description 多表联查-分页 * @Author songwp * @Date 2022/8/8 10:31 * @Version 1. ...

  5. C语言:通讯录程序设计(多功能)

    回顾我的代码shi 通讯录程序设计 主函数 遇到的困难 补充标注说明(一定要看) 效果展示截图 结语 程序源代码 通讯录程序设计 作者前言:该通讯录作品是我大一的C语言结课作业,代码像shi山一样,之 ...

  6. 使用Redis实现短信登陆

    使用Redis实现发送验证码:验证码登陆.注册:登陆校验拦截.登陆状态刷新等一系列问题. 验证码发送和验证登陆注册 思路流程 整体的思路以及流程如题: 代码实现 实体类 User实体类 @Data @ ...

  7. SQL 分析与优化神器,验证了真相定律

    引言 今天要分享的是一个 SQL 语句分析的神器,它是一个基于 Soar 的开源 sql 分析与优化的 Web 图形化工具.我们在平常分析 SQL 语句,使用最多的方式就是 Explain 工具.了解 ...

  8. Vue 页面传参方式 Query 和 Params

    1. query 与 params 传参 query 需要和配合 path 属性使用,携带参数会拼接在请求路径后,效果同 Get 请求方式 http://localhost:8033/Permissi ...

  9. 【VMware vSphere】使用vSphere Lifecycle Manager(vLCM)管理独立主机和集群的生命周期。

    vSphere Lifecycle Manager(vLCM)是 vSphere 7 中引入的一项新功能,它提供了一种集中式.自动化和简单性的方式来管理和升级 vSphere 基础架构组件(如vCen ...

  10. Java中GUI

    目录 1.Java GUI 概述 2.容器 2.1 窗口 2.2 弹窗和对话框 对话框 自定义弹窗 2.3 面板 普通面板 滚动面板 分隔面板 选项卡面板 3.布局 3.1.流式布局 3.2.网格布局 ...