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

  介绍

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

def  find_worldByName (c_name,大陆):   ,,,印刷(c_name)   ,,,印刷(大陆)   ,,,sql =,,, SELECT  *,得到world  WHERE , 1=1,“   ,,,如果(c_name !=None):   ,,,,,,,sql=sql +“;以及(,c_name  LIKE  & # 39; %“+ c_name +“% & # 39;,)“;   ,,,如果(大陆!=None):   ,,,,,,,sql=sql +“,以及(,continent  LIKE  & # 39; %“+大陆+“% & # 39;),“   ,,,sql=sql +“,以及dt=(SELECT  dt 得到world  order  by  dt  desc  limit  1), order  by  confirm  desc “      ,,,,,,,,,#,“以及continent  LIKE  & # 39; % % % % % s % % % % & # 39;“\   ,,,,,,,,,,号“,order  by  dt  desc “, % (c_name大陆)   ,,,#,sql_temp =,,, SELECT  *,得到world  WHERE  c_name  LIKE  & # 39; %“+ c_name +“% & # 39;,“   ,,,res =,查询(sql)   ,,,=列表,[]   ,,,for 小姐:拷贝res:   ,,,,,,,#,打印(我)   ,,,,,,,list.append(我)   ,,,return 列表;

背景:

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

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

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

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

思路:

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

sql =,,, SELECT  *,得到world  WHERE  1=1,“

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

如果(c_name !=None):   ,,,,,,,,,sql=sql +“;以及(,c_name  LIKE  & # 39; %“+ c_name +“% & # 39;,)“;   ,,,,,如果(大陆!=None):   ,,,,,,,,,sql=sql +“,以及(,continent  LIKE  & # 39; %“+大陆+“% & # 39;),“   ,,,,,sql=sql +“,以及dt=(SELECT  dt 得到world  order  by  dt  desc  limit  1), order  by  confirm  desc “

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

var  c_name=皌est"   sql_temp =,,, SELECT  *,得到world  WHERE  c_name  LIKE  & # 39;, %“+ c_name +, %, & # 39;“

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

sql =,,, SELECT  *,得到world  WHERE  c_name  LIKE  & # 39; % % % % % s % % % % & # 39;,以及continent  LIKE  & # 39; % % % % % s % % % % & # 39;“, % (c_name大陆)

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

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

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