Поиск нескольких данных таблицы в codeigniter - PullRequest
1 голос
/ 24 февраля 2020

Таблица, которую вы выбираете при поиске по почтовому индексу, приносит данные из выбранной таблицы БД. Но я не знаю, как это сделать. Пожалуйста, помогите мне. У меня есть 3 таблицы в моей базе данных tblcaregiver. tblfamily, tblprovider.

Это процесс, который я хочу найти .. Search view

Это таблица БД .. .

Db table

Вид

<div class="serc-title">Search User</div>
<div>
    <div class="input-group mb-4">
        <form action="<?php echo site_url('provider/dashboard/search_keyword');?>" method="post">
            <input type="text" name = "keyword" required="required" value="<?php if(isset($searching_data)){echo $searching_data; } ?>" />
            <input type="submit" value = "Search" />
        </form>
    </div>
</div>

<h5 class="header-title mb-0">Potential Clients</h5>
<div class="table-responsive">
    <?php if(isset($zipcode_serching_results)){ ?>
    <?php if(!empty($zipcode_serching_results)){ ?>
        <h5 class="header-title mb-0">Potential Caregivers</h5>
        <div class="table-responsive">
            <table class="table table-bordered">
                <thead>
                    <tr>
                        <td>Telephone</td>
                        <td>Zipcode</td>
                        <td>Email</td>
                    </tr>
                </thead>
                <tbody>
                    <?php foreach($zipcode_serching_results as $row){ ?>
                        <tr>
                            <td><?php echo $row->tele ?></td>
                            <td><?php echo $row->zipcode ?></td>
                            <td><?php echo $row->emailid ?></td>
                        </tr>
                    <?php } ?>
                </tbody>
            </table>
        </div>
    <?php }else{ ?>
    <div>
        <h4 style="color: #999">Zipcode not found</h4>
    </div>
    <?php } } ?>
</div>

Контроллер

public function search_keyword() {
    $keyword = $this->input->post('keyword');
    $data['zipcode_serching_results'] = $this->Provider_Profile_Model->search($keyword);
    $data['searching_data'] = $keyword;

    $userid = $this->session->userdata('uid');
    $data['profile'] = $this->Provider_Profile_Model->getprofile($userid);
    $this->load->view('provider/dashboard', $data);
}

Модель

public function search($keyword) {
  $this->db->like('zipcode', $keyword);
  $query = $this->db->get('tblfamily')->result();
  return $query;
}

1 Ответ

1 голос
/ 24 февраля 2020

Сначала вы должны добавить в форму тег выбора с опциями таблицы

<select id="tables" name="tables" form="ID-OF-YOUR-FORM-HERE">
  <option value="tblcaregiver">tblcaregiver</option>
  <option value="tblfamily">tblfamily</option>
  <option value="mercedes">Mercedes</option>
  <option value="tblprovider">tblprovider</option>
</select>

Затем вам нужно получить выбранные данные в вашем контроллере и передать их вашей модели

public function search_keyword() {
    $keyword = $this->input->post('keyword');
    // fetch selected table 
    $table = $this->input->post('tables');
    $data['zipcode_serching_results'] = $this->Provider_Profile_Model->search($keyword, $table); // 2nd parametar added
    $data['searching_data'] = $keyword;

    $userid = $this->session->userdata('uid');
    $data['profile'] = $this->Provider_Profile_Model->getprofile($userid);
    $this->load->view('provider/dashboard', $data);
}

Наконец, обновите модель и динамически выберите таблицу

public function search($keyword, $table) {
  $this->db->like('zipcode', $keyword);
  $query = $this->db->get($table)->result();
  return $query;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...