Может кто-нибудь объяснить мне, когда я повторяю переменную $ rows_affected, почему я получаю только 1, когда мне нужно получить 2 на основе записей db? Больше, чем полчаса, пытаясь разобраться в этом и все еще не могу решить его. По-прежнему noob на PDO.Php PDO неверный подсчет строк
Любые другие советы приветствуются.
$sql1 = "SELECT title FROM page WHERE id=?";
$stm = $db->prepare($sql1);
$stm->execute(array($id));
$row1 = $stm->fetch(PDO::FETCH_ASSOC);
$sql2 = "SELECT id,title,pg_title FROM page WHERE title=? ORDER BY id ASC";
$stm = $db->prepare($sql2);
$stm->execute(array($row1['title']));
$rows_affected = $stm->fetchColumn();
if (count($rows_affected) > 0) {
for($i=0; $i <= $rows_affected; $i++) {
$row2 = $stm->fetch(PDO::FETCH_ASSOC);
if($row2['id']==$id){
echo '<a href="javascript: void(0)"><b>'.$row2['pg_title'].'</b></a> ';
}else{
echo '<a href="page.php?id='.$row2['id'].'';?><?php if(isset($_GET['edit']) && $_GET['edit']==1){ echo '&edit=1';}?><?php echo'">'.$row2['pg_title'].'</a> ';
}
}
}
Это 'fetchColumn()' получит значение столбца 'id' из первого результата второго запроса, это не имеет никакого отношения к количеству найденных записей. Вы имели в виду сделать 'rowCount()'? Обратите внимание, что подход 'rowCount()' будет работать только с MySQL. Также обратите внимание, что '$ rows_affected' будет скалярным значением в любом случае, и поэтому' count() 'не имеет никакого смысла в связи с ним. – DaveRandom
Спасибо, что сработало сперва! Глупая ошибка. Когда вы говорите, что rowCount() будет работать только с mysql, вы имеете в виду, что он работает только в том случае, если im кодирование в mysql? Ps: Мой английский не очень жаль – miguelfsf
@miguelfsf Звучит нормально для меня :) –