我有一个包含多个select的下拉框。下拉看起来是这样的:PDO FetchAll返回一个空数组,但数据库中存在值
<select multiple class="form-control" name="batch_no[]" id="batch_no" required onchange="getBatchCourseDetail();">
<option value="">-----------Select Your Batch----------</option>
<?php
foreach ($result as $res)
{
?>
<option value="<?php echo $res['batch_code']; ?>"><?php echo $res['batch_code']; ?></option>
<?php
} ?>
</select>
在平变化的函数调用我有这样的脚本:
function getBatchCourseDetail()
{
var other = String($('#batch_no').val());
var opts = [],
opt;
var split1 = other.split(',');
for (var i = 0; i < split1.length; i++)
{
opt = split1[i];
opts.push(opt);
}
$.ajax({
url: 'course_apply_batch_course_detail_ajax.php',
type: 'POST',
data:
{
batch_code: opts
},
success: function (data)
{
//console.log(data);
$('#batch_information_autofill').html(data);
}
});
}
在AJAX文件,是在course_apply_course_detail_ajax.php页面检索到下降的所有值下 。
course_apply_course_detail_ajax.php:
<?php
require('classes/autoloader.php');
$course_apply = new \Model\CourseApplyModel();
$batch_code111=array();
$batch_code111 = $_POST['batch_code'];
$batch_code1 ="'" .implode("','",$batch_code111) ."'";
$parameter = array(
"batchcode" => $batch_code1,
"status" => 0);
$result11 =$course_apply->getBatchCourseDetail11($parameter);
echo"<pre>";
print_r($result11);
echo"</pre>";
exit;
?>
我将获得$ batch_code1值: 'LATS-CHMB-1000', 'LATS-SA-1000', 'LATS-ABSE-1003',这是存储在数组变量'batchcode'中。
在型号我的查询看起来是这样的:
public function getBatchCourseDetail11($parameter)
{
/* $QUERY1="SELECT start_date,end_date,course_code FROM batch WHERE
batch_code IN('LATS-CHMB-1000','LATS-SA-1000','LATS-ABSE-1003') AND status =0"; */
$query1="SELECT start_date,end_date,course_code FROM batch WHERE status =:status AND batch_code IN(:batchcode)";
try{
$result1=$this->dbh->prepare($query1);
$result1->execute($parameter);
$data11=$result1->fetchAll(\PDO::FETCH_ASSOC);
return $data11;
}
catch(\PDOException $e)
{
print_r($e);
return false;
}
}
当我尝试打印返回的数据我得到阵列(),但查询的phpMyAdmin的正确执行。
在此先感谢请帮我解决这个问题。
你在使用换码反斜杠吗? –
@ Maksim.T你的意思是:$ course_apply = new \ Model \ CourseApplyModel();它为这个类创建一个对象。 – user12688
不,我的意思是当你用PDO组成你的数组并捕获一个异常。即catch(\ PDOException $ e) –