Следующее также хорошо:
if($query1->num_rows() > 0){
$row = $query1->row();
}
return $row->dPassword;
Тогда, если ваш запрос должен был вернуть более одной строки, вы могли бы обработать результаты следующим образом:
foreach($query1->result() as $row){
echo $row->field1;
echo $row->field2;
echo $row->etcetera;
}
Для результатов с одной строкой я обычно возвращаю строку непосредственно из модели, например:
return $query1->row();
Вот пример этого:
function select_provider_details($provider_id)
{
$this->db->select('*');
$this->db->from('providers');
$this->db->where('provider_id', $provider_id);
$query = $this->db->get();
if($query->num_rows() > 0)
{
$result['success'] = TRUE;
$result['query'] = $query->row();
}
else
{
$result['success'] = FALSE;
$result['error'] = "Provider not found in database";
$result['errorcode'] = "E003";
$result['query'] = $query->row();
}
return $result;
}
Или для запроса, который должен вернуть несколько результатов, я возвращаю весь объект результатов:
return $query1;