doushi1473 2015-06-11 07:09
浏览 205
已采纳

选择多个条件

In form user need to check options who will receive newsletter, for example:

<input type="checkbox" name="male"  value="1" />
<input type="checkbox" name="female"  value="1" />
<input type="checkbox" name="person" value="1" />
<input type="checkbox" name="company" value="1" /> 

But I have problem how to create query for db with checked options

I have this code so far, but it is not good, because newsletter need to be 1 all the time and after that I have OR, because when I put AND I don't get the results that I need:

if($options['male']) {
            $sqlAddMale = " OR gender = 2 ";
        }
        if($options['female']) {
            $sqlAddFemale = " OR gender = 1 ";
        }
        if($options['person']) {
            $sqlAddPerson = " OR VAT = '' ";
        }
        if($options['company']) {
            $sqlAddCompany = " OR VAT <> '' ";
        }

        $query = "
            SELECT email FROM users WHERE newsletter=1
            ".$sqlAddMale."
            ".$sqlAddFemale."
            ".$sqlAddPerson."
            ".$sqlAddCompany."          
            ";
  • 写回答

2条回答 默认 最新

  • doutan3040 2015-06-11 07:26
    关注

    I think You need something like this:

    $placeOr = false;
    if($options['male']) {
        $placeOr = true;
        $sqlAddMale = " (newsletter=1 AND gender = 2) ";
    }
    if($options['female']) {
        $sqlAddFemale = (($placeOr)?" Or ":"");
        $sqlAddFemale .= " (newsletter=1 AND gender = 1) ";
        $placeOr = true;
    }
    if($options['person']) {
        $sqlAddPerson = (($placeOr)?" Or ":"");
        $sqlAddPerson .= " (newsletter=1 AND VAT = '') ";
        $placeOr = true;
    }
    if($options['company']) {
        $sqlAddCompany = (($placeOr)?" Or ":"");
        $sqlAddCompany .= " (newsletter=1 AND VAT <> '') ";
        $placeOr = true;
    }
    
    $query = "
        SELECT email FROM users WHERE 
        ".$sqlAddMale."
        ".$sqlAddFemale."
        ".$sqlAddPerson."
        ".$sqlAddCompany."          
        ";
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图