dongyuqie4322 2017-09-26 07:44
浏览 15
已采纳

从db显示名称而不是id无法正常工作

I am trying to display a name from db instead of id (sittername) but my view it shows the same name in all rows which is wrong. What I want is to get the name from db for every id in $ids array. I hope you can help me. I am using MVC in CodeIgniter framework..

My Controller:

$results = $this->Admin_model->getSitter_Requests($config["per_page"], $page);

        foreach ($results as $item)
        {
            $data['data1'] = [];
            $sitter_job_id = $item['sitter_job_id']; 

My problem is in this part of code, sittername has only one name which come from the last id in my $ids array. what I want is to get the name from db for every id in $ids array.

    $ids = $item['sitter_id']; 

    foreach ((array)$ids as $id)
    {
        if($id != 0 && $id != null){
            $sittername = $this->Admin_model->get_sitter_name($id[0]); 
            $data["sittername"] = $sittername;
        }

    }
    }


        $data["results"] = $results;
        $data["links"] = $this->pagination->create_links();

        $this->load->view('admin/superadmin_sitter_requests',$data);

My Model:

public function getSitter_Requests($limit, $start)
    {
        $this->db->select('*');
        $this->db->limit($limit, $start);
        $query = $this->db->get('ps_sitter_jobs');
        if ($query->num_rows() > 0) {
            foreach ($query->result_array() as $row) {
                $data[] = $row;
            }
            return $data;
        }
        return array();

    }
function get_sitter_name($id) {

        $this->db->select('fname');
        $this->db->where('id', $id);
        $query = $this->db->get('ps_cms_users');
        return $query->row()->fname;

    }
ps_sitter_jobs table columns:
sitter_job_id                  | int(11)   PRI                
sitter_id                      | int(11)   FK from ps_cms_users(id)                
seller_sitter_id               | int(11)                   
token_trans_id                 | varchar(255)              
camp_id                        | int(11)                   
book_id                        | int(11)                   
sitter_status                  | enum('0','1','2','3','4') 
created_date                   | datetime                  
modify_date                    | datetime                  
assign_new_sitter_btn_disabled | int(11)                   
refund_btn_disabled            | int(11)     
===================================================
ps_cms_users table columns:
id           | int(11)       PRI  
email        | varchar(128) 
password     | varchar(128) 
fname        | varchar(128) 
lname        | varchar(128) 
mobile       | varchar(20)  
roleId       | int(4)       
createdBy    | int(11)      
createdDtm   | datetime     
updatedBy    | int(11)      
updatedDtm   | datetime     
partner_type | int(11)      
state        | int(11)      
city         | int(11)      
userDesc     | varchar(255)   
==================================================

My View:

if(count($results) > 0){
    foreach ($results as $result){
        $result_id = $result['sitter_job_id'];
    ?>
        <tr>
            <td>
                <?php echo '#'.$result_id; ?>
            </td>
            <td>
                <?php 
                if($result['sitter_id'] == 0 || $result['sitter_id'] == null)
                {
                    echo "Sitter Not Assigned yet";
                }
                else
                {                   
                    echo $sittername; 

                }
    }   
    ?>
  • 写回答

1条回答 默认 最新

  • dongya4335 2017-09-26 15:04
    关注

    Not very easy to fully understand what you're trying to accomplish here, but I think you could use a JOIN instead of looping trough your first results. Here's a suggestion. (I have left out pagination and HTML formatting for the purpose of clarity)

    Your Controller

    $data["results"] = $this->Admin_model->getSitter_Requests();
    $this->load->view('admin/superadmin_sitter_requests', $data);
    

    Your Model (Admin_model.php)

    public function getSitter_Requests()
    {
        $this->db->join('ps_cms_users', 'ps_cms_users.id = ps_sitter_jobs.sitter_id');
        return $this->db->get('ps_sitter_jobs')->result();
    }
    

    Your View (admin/superadmin_sitter_requests)

    foreach ($results as $result)
    {
        echo 'SITTER_JOB_ID = ' . $result['sitter_job_id'];
        echo 'SITTER_ID = ' . $result['sitter_id'];
        echo 'SITTER_FIRSTNAME = ' . $result['fname']; 
    }
    

    I hope this helps.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 怎样才能让鼠标沿着线条的中心线轨迹移动
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?