广告
返回顶部
首页 > 资讯 > 数据库 >怎么在Python中使用sql语句多条件模糊查询mysql数据库
  • 726
分享到

怎么在Python中使用sql语句多条件模糊查询mysql数据库

2023-06-14 12:06:54 726人浏览 泡泡鱼
摘要

怎么在python中使用sql语句多条件模糊查询mysql数据库?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。def find_worldByName(c_nam

怎么在python中使用sql语句多条件模糊查询mysql数据库?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

def find_worldByName(c_name,continent):    print(c_name)    print(continent)    sql = " SELECT * FROM world WHERE  1=1 "    if(c_name!=None):        sql=sql+"AND ( c_name LIKE '%"+c_name+"%' )"    if(continent!=None):        sql=sql+" AND ( continent LIKE '%"+continent+"%') "    sql=sql+" AND dt=(SELECT dt FROM world order by dt desc limit 1) order by confirm desc "          # "AND continent LIKE '%%%%%s%%%%'" \          # " order by dt desc " %(c_name,continent)    # sql_temp = " SELECT * FROM world WHERE c_name LIKE '%"+c_name+"%' "    res = query(sql)    list= []    for i in res:        # print(i)        list.append(i)    return list;

背景:

页面的搜索框是有两个搜索条件,一个是国家,一个是大洲。

那么在数据库查询的时候就会出现问题,如果国家传的值是None那么使用AND连接的sql语句这个条件会被

整体判定为false,也就是另一个查询条件 “大洲 ”就会作废,为了防止参数出现这样的错误。需要在写sql语

句的时候对参数是否为空加一个判断条件,然后逐层添加sql语句。

思路:

首先使用开头的一个sql语句:

sql = " SELECT * FROM world WHERE 1=1 "

之后逐层判定参数是否为空,再拼接sql语句:

if(c_name!=None):          sql=sql+"AND ( c_name LIKE '%"+c_name+"%' )"      if(continent!=None):          sql=sql+" AND ( continent LIKE '%"+continent+"%') "      sql=sql+" AND dt=(SELECT dt FROM world order by dt desc limit 1) order by confirm desc "

还有一个地方需要注意:
sql语句传参数,参数是一个变量,有两种方式:
① 直接拼接到sql语句中:

var c_name="test"sql_temp = " SELECT * FROM world WHERE c_name LIKE ' %"+c_name+"% '"

② 使用占位符%代替,在语句末尾再替换占位符:

sql = " SELECT * FROM world WHERE c_name LIKE '%%%%%s%%%%' AND continent LIKE '%%%%%s%%%%'" %(c_name,continent)

怎么在Python中使用sql语句多条件模糊查询mysql数据库

关于怎么在Python中使用sql语句多条件模糊查询Mysql数据库问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网数据库频道了解更多相关知识。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么在Python中使用sql语句多条件模糊查询mysql数据库

本文链接: https://www.lsjlt.com/news/270690.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作