Когда я делаю это, цикл foreach отлично работает., равный аргументу PHP и данным mysql, делает цикл foreach неработоспособным
<?php
function checkInDB($NIC){
$user='root';
$pass='123';
$db='mysql:host=localhost;dbname=recruit';
$dbh= new PDO($db,$user,$pass);
$sql = 'SELECT FirstName
FROM cv
JOIN candidate ON cv.cvID=candidate.cvID
WHERE ((submittedDate > NOW() - INTERVAL 365 day)
AND (candidate.NIC="906548765V"))';
echo '<h3>candidates</h3>', '<hr />', PHP_EOL;
echo '<table border=1>', PHP_EOL;
foreach ($dbh->query($sql, PDO::FETCH_ASSOC) as $row) {
echo '<tr><td>', implode('</td><td>', $row), '</td></tr>', PHP_EOL;
}
echo '</table>', PHP_EOL;
}
checkInDB("906548765V");
?>
, но когда я просто изменить (candidate.NIC="906548765V")
к (candidate.NIC=$NIC)
, который даже делает echo ($NIC==="906548765V");
истинное, бросает непредвиденную ошибку
Недействительный аргумент для Еогеасп()
Что именно там происходит ?
Это происходит потому, что ваша строка '$ sql' построен в одинарные кавычки и одинарные кавычки не интерпретирует переменные (см http://stackoverflow.com/questions/3446216/ what-is-the-difference-between-single-quoted-and-double-quoted-strings-in-php) –