Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/235.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 使用多个where子句选择框多个选项_Php_Pdo_Jquery Chosen - Fatal编程技术网

Php 使用多个where子句选择框多个选项

Php 使用多个where子句选择框多个选项,php,pdo,jquery-chosen,Php,Pdo,Jquery Chosen,我有一个包含承包商和州的选择框。用户可以选择任意数量的承包商或州进行搜索。如何使用此多选框获取电子邮件地址?我的问题是,他们可以选择多个承包商,多个州,或者根本没有州,等等 在所有这些情况下,我将如何获取电子邮件 选择框: <select name="CID[]" id="CID[]" class="chosen-select" multiple="multiple"> <option value="All">All Active Contractors</

我有一个包含承包商和州的选择框。用户可以选择任意数量的承包商或州进行搜索。如何使用此多选框获取电子邮件地址?我的问题是,他们可以选择多个承包商,多个州,或者根本没有州,等等

在所有这些情况下,我将如何获取电子邮件

选择框:

<select name="CID[]" id="CID[]" class="chosen-select" multiple="multiple">
    <option value="All">All Active Contractors</option>
    <?php foreach ($cq as $row): ?>
    <option value="<?=$row['CID']?>"><?=$row['name']?></option>
    <?php endforeach; ?>
    <option value="AL">Alabama</option>
    <option value="AK">Alaska</option>
    <option value="AZ">Arizona</option>
    <option value="AR">Arkansas</option>
    <option value="CA">California</option>
    <option value="CO">Colorado</option>
    <option value="CT">Connecticut</option>
    <option value="DE">Delaware</option>
    <option value="FL">Florida</option>
    <option value="GA">Georgia</option>
    <option value="HI">Hawaii</option>
    <option value="ID">Idaho</option>
    <option value="IL">Illinois</option>
    <option value="IN">Indiana</option>
    <option value="IA">Iowa</option>
    <option value="KS">Kansas</option>
    <option value="KY">Kentucky</option>
    <option value="LA">Louisiana</option>
    <option value="ME">Maine</option>
    <option value="MD">Maryland</option>
    <option value="MA">Massachusetts</option>
    <option value="MI">Michigan</option>
    <option value="MN">Minnesota</option>
    <option value="MS">Mississippi</option>
    <option value="MO">Missouri</option>
    <option value="MT">Montana</option>
    <option value="NE">Nebraska</option>
    <option value="NV">Nevada</option>
    <option value="NH">New Hampshire</option>
    <option value="NJ">New Jersey</option>
    <option value="NM">New Mexico</option>
    <option value="NY">New York</option>
    <option value="NC">North Carolina</option>
    <option value="ND">North Dakota</option>
    <option value="OH">Ohio</option>
    <option value="OK">Oklahoma</option>
    <option value="OR">Oregon</option>
    <option value="PA">Pennsylvania</option>
    <option value="RI">Rhode Island</option>
    <option value="SC">South Carolina</option>
    <option value="SD">South Dakota</option>
    <option value="TN">Tennessee</option>
    <option value="TX">Texas</option>
    <option value="UT">Utah</option>
    <option value="VT">Vermont</option>
    <option value="VA">Virginia</option>
    <option value="WA">Washington</option>
    <option value="WV">West Virginia</option>
    <option value="WI">Wisconsin</option>
    <option value="WY">Wyoming</option>
    </select>
如果他们选择All,我可以查询所有内容,因为我刚刚删除了大部分where子句:

SELECT CM.email, HO.name, HO.lastname 
FROM tbl_ContactMethods AS CM
JOIN tbl_HomeOwner AS HO ON HO.HID = CM.HID
JOIN tbl_PressControl AS PC ON PC.HID = HO.HID
WHERE PC.active = 1 AND CM.email IS NOT NULL

您必须在“contractor1”、“contractor2”、“等等”中使用

$contractorquery = $db->prepare("SELECT CM.email, HO.name, HO.lastname, LL.state 
FROM tbl_ContactMethods AS CM
JOIN tbl_HomeOwner AS HO ON HO.HID = CM.HID
JOIN tbl_Locations AS LL ON LL.HID=HO.HID
JOIN tbl_PressControl AS PC ON PC.HID = HO.HID
WHERE PC.CID IN('contratcor1','contractor2','and so ON') AND LL.state = ??????  AND     
PC.active = 1 AND CM.email IS NOT NULL");
$contractorquery = $db->prepare("SELECT CM.email, HO.name, HO.lastname, LL.state 
FROM tbl_ContactMethods AS CM
JOIN tbl_HomeOwner AS HO ON HO.HID = CM.HID
JOIN tbl_Locations AS LL ON LL.HID=HO.HID
JOIN tbl_PressControl AS PC ON PC.HID = HO.HID
WHERE PC.CID IN('contratcor1','contractor2','and so ON') AND LL.state = ??????  AND     
PC.active = 1 AND CM.email IS NOT NULL");