Проблема с codeigniter 4 Классы построителя запросов

На терминале в mysql выполнение следующего запроса дает этот результат

mysql> SELECT DISTINCT(city) FROM outlets_data;
+-----------+
| city      |
+-----------+
| Paris     |
| New York  |
| Kolkata   |
| Moscow    |
| Mumbai    |
| Hyderabad |
| Delhi     |
| Chennai   |
+-----------+
8 rows in set (0.00 sec)

Я хочу сохранить названия этих городов в массиве в файле класса моделей codeigniter 4.

Модели/DashboardModels.php

<?php

namespace App\Models;

use CodeIgniter\Model;

class DashboardModel extends Model
{
    protected $table      = 'outlets_data';
    protected $primaryKey = 'shop_id';

    public function not_defined_yet()
    {
        $city_names = $this->select('city')->distinct(); // This should be equivalent to "SELECT DISTINCT(city) FROM outlets_data";
        
        return $city_names;
    }
}

Контроллер/Home.php

<?php

namespace App\Controllers;

use App\Models\DashboardModel;

use CodeIgniter\Model;

class Home extends BaseController
{
    public function index()
    {
        $model = new DashboardModel();
        $data['undefined'] = $model->not_defined_yet();

        echo view('dashboard', $data);
    }
}

Представления/Dashboard.php

 <?php echo "<pre>";  print_r($undefined); echo "</pre>"; ?>

Я ожидаю получить названия городов в выходном массиве, но я получаю всю базу данных как ассоциативный массив.


person kashish    schedule 18.02.2021    source источник


Ответы (1)


Ваша функция должна быть:

public function not_defined_yet()
{
    $city_names = $this->select('city')->distinct(); // This should be equivalent to "SELECT DISTINCT(city) FROM outlets_data";
    
    return $this;
}

Тогда ваша функция будет

$data['undefined'] = $model->not_defined_yet()->findAll();

Другой способ сделать это — загрузить новый экземпляр объекта базы данных.

public function not_defined_yet()
{

    $db         = \Config\Database::connect();
    $builder    = $db->table('outlets_data');
    $city_names = $builder->select('city')->distinct(); 
    
    return $city_names->resultArray();
}

Вы даже можете удалить функцию все вместе и в своем контроллере сделать это:

$data['undefined'] = $model->select('city')->distinct()->findAll();

Это даст тот же точный результат.

person marcogmonteiro    schedule 18.02.2021