Отображать данные из трех таблиц с общим идентификатором в foreach

Итак, в настоящее время у меня есть три таблицы, приведенные ниже:

AI = автоинкремент.

ci_users: user_id (AI), имя пользователя, слаг, электронная почта, биография.

ci_terms: term_id (AI), название, слизняк, тело.

ci_relationship: id (AI), term_id, user_id, тип.

Я пытаюсь отобразить всех пользователей из определенного term_id (где тип это навык),

например, скажем term_id 3 (где term_id имеет название «CSS» из ci_terms).

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

ПАРАГРАФЫ НИЖЕ, ПОСЛЕ ТОГО, КАК НАЖМИТЕ УКАЗАТЕЛЬНЫЙ ТЕРМИН (SKILL).

Это функция, которая показывает мне всех пользователей, у которых в качестве навыка используется term_id (из моего предыдущего вопроса о Stackoverflow. Спасибо Прадип кто помог мне решить этот вопрос:

// All users with specific skill
public function get_user_skill($id)
{

$this->db->select('*, count(ci_relationship.term_id)');
$this->db->from($this->table);
$this->db->join('ci_relationship', 'ci_relationship.user_id = ci_users.id', 'INNER');
$this->db->order_by('ci_relationship.user_id', 'DESC');
$this->db->group_by('ci_relationship.user_id');
$this->db->where('ci_relationship.term_id', $id);
$this->db->where('ci_relationship.type', 'skill');

$query = $this->db->get();

if($query->num_rows() > 0)
{
return $query->result();
}
else
{
return false;
}
}

Как я уже говорил, приведенный выше код просто отображает пользователей с определенным term_id. Теперь это метод в контроллере, который показывает ожидаемые данные (пользователи с определенным term_id):

Это мой контроллер:

public function skill($id){

// Get data
$data['users'] = $this->User_model->get_user_skill($id);
$term = $this->Terms_model->get($id);

// Get skill name
$data['skill'] = $this->Terms_model->get($id);

// Get skills per foreach --- HERE IS WHERE I NEED HELP
$data['skills'] = $this->User_model->skills($id);

// Meta
$data['title']  = $this->settings->title.' | '. ucfirst($term->title);

// Load template
$this->template->load('public', 'default', 'users/skill', $data);
}

Это метод, который я пытаюсь создать, чтобы отображать term_id для user_id:

// Skill for user foreach
public function skills($id){

$this->db->select('*');
$this->db->from($this->relationship);
$this->db->where('term_id', $id);
$this->db->where('type', 'skill');
$this->db->order_by('id', 'DESC');

$query = $this->db->get();

if($query->num_rows() >= 1){
return $query->result();
} else {
return false;
}

}

Представление следующий код:

<?php if($users) : ?>
<div class="row">
<?php foreach($users as $user) : ?>
<div class="col-lg-3 col-sm-6">
<div class="card text-center panel">
<div class="cardheader panel-heading" style="background: url(<?php if($user->user_id) : echo base_url('assets/img/users/covers/'.get_username($user->user_id).'/'.get_username_cover($user->user_id)); else : echo base_url().'assets/img/noavatar.jpg'; endif ?>)no-repeat center center;"></div>
<div class="avatar">
<a target="_self" href="<?= base_url('users/profile/'.get_username($user->user_id)); ?>"><img class="img-circle" alt="<?= get_username($user->user_id); ?> profile picture" title="<?= get_username($user->user_id); ?> profile picture" src="<?php if($user->user_id) : echo base_url('assets/img/users/avatars/'.get_username($user->user_id).'/'.get_username_avatar($user->user_id)); else : echo base_url().'assets/img/noavatar.jpg'; endif ?>"></a>
</div>
<div class="info panel-body">
<div class="title">
<a target="_self" href="<?= base_url('users/profile/'.get_username($user->user_id)); ?>"><?= get_username($user->user_id); ?></a>
</div>
<div class="desc"><?php if(get_occupation($user->user_id)) : ?><?= get_occupation($user->user_id); ?><?php else : echo 'No Job'; endif ?> <?php if(get_company($user->user_id)) : ?> - <b><?= get_company($user->user_id); ?></b><?php else : echo '- <b>No Company</b>'; endif ?></div>
<!-- BEGINNING OF HERE IS WHERE I NEED HELP -->
<?php if($skills) : ?>
<?php foreach($skills as $skill) : ?>
<span class="label label-orange"><?= get_term($skill->term_id) ?></span>
<?php endforeach ?>
<?php endif ?>
<!-- END OF HERE IS WHERE I NEED HELP -->
</div>
</div>
</div>
<?php endforeach; ?>
</div>
<?php else : ?>
<div class="alert alert-danger">No user with <?= $skill->title ?> skill found</div>
<?php endif; ?>

Это фактический результат:

фактический вывод отображаемых пользователей со своими навыками

И это ожидаемый результат:

ожидаемый вывод отображаемых пользователей со своими навыками

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

1

Решение

Надеюсь, что это поможет вам :

Создать helper метод get_skill_by_user как get_username или же get_occupation и использовать его на ваш взгляд

function get_skill_by_user($user_id, $id)
{
$ci = & get_instance();
$ci->db->select('*');
$ci->db->from('ci_relationship');
$ci->db->where('term_id', $id);
$ci->db->where('user_id', $user_id);
$ci->db->where('type', 'skill');
$ci->db->order_by('id', 'DESC');

$query = $ci->db->get();

if($query->num_rows() > 0)
{
return $query->result();
} else
{
return false;
}
}

По вашему мнению, ваш цикл навыков должен быть таким:

<?php $user_skills = get_skill_by_user($user->user_id, $user->term_id); if($user_skills) : ?>
<?php foreach($user_skills as $skill) : ?>
<span class="label label-orange"><?= get_term($skill->term_id) ?></span>
<?php endforeach ?>
<?php endif ?>
1

Другие решения

Других решений пока нет …