1

所以我目前有下面给出的三个表:

AI = 自动递增。

ci_users: user_id(AI)、用户名、slug、电子邮件、传记。

ci_terms: term_id(AI)、title、slug、body。

ci_relationship: id(AI)、term_id、user_id、类型。

我正在尝试显示来自特定 term_id 的所有用户(其中​​类型是技能),

例如,假设 term_id 3(其中 term_id 具有来自 ci_terms 的“CSS”标题)。

为了更清楚起见,上面的段落基本上说向我展示所有具有 CSS 技能的用户,但我希望显示的用户展示他们存储在 ci_relationship 表中的所有其他技能。

下面的段落是在点击特定的 TERM_ID(SKILL) 之后。

这是向我展示所有以 term_id 作为技能的用户的功能。(来自我之前的 Stackoverflow 问题。感谢pradeep帮助我解决了该查询:

// 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);
}

这是我试图创建以显示每个 user_id 的 term_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; ?>

这是实际输出:

显示用户的实际输出与他们自己的技能

这是预期的输出:

具有自己技能的显示用户的预期输出

我希望我能很好地解释自己以使其易于理解,在此先感谢。

4

1 回答 1

1

希望对你有帮助 :

像or一样创建一个helper方法并在你的视图中使用它get_skill_by_userget_usernameget_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 ?>
于 2018-07-20T11:00:39.883 回答