CodeIgniter,Active Records获取第二个表值

时间:2014-09-20 04:09:14

标签: php mysql sql codeigniter activerecord

我对此有点疑惑......

我创建了一个简单的博客,我无法从帖子中获得所需的输出,我想要的是我想通过使用第一个表中的userID从第二个表中获取名字和姓氏

控制器/ posts.php:

<?php

class Posts extends CI_Controller {

    function __construct() {
        parent::__construct();
        $this->load->model('post');
    }

    function index() {
        $data['posts'] = $this->post->get_posts();
        $data['users'] = $this->post->get_users();
        $this->load->view('post_index', $data);
    }

    function post($postID) {
        $data['post'] = $this->post->get_post($postID);
        $this->load->view('post', $data);
    }

    function correct_permissions($required) {
        $user_type = $this->session->userdata('user_type');
        if ($required == "User") {
            if ($user_type) {
                return true;
            }
        } elseif ($required == "Blogger") {
            if ($user_type == "Blogger") {
                return true;
            }
        }
    }

    function deletepost($postID) {
        $user_type = $this->session->userdata('user_type');
        if ($user_type != 'Blogger') {
            echo "<script>alert:('Please log in to continue.');</script>";
            redirect(base_url());
        }
        $this->post->delete_post($postID);
        redirect(base_url() . 'posts');
    }

}

模型/ post.php中

<?php

class Post extends CI_Model{
    function get_posts($num=50,$start=0){
        $this->db->select()->from('posts')->where('active',1)->order_by('date_added','desc')->limit($num,$start);
        $query = $this->db->get();
        return $query->result_array();
    }

    function get_post($postID){
        $this->db->select()->from('posts')->where(array('active'=>1,'postID'=>$postID))->order_by('date_added','desc');
        $query=$this->db->get();
        return $query->first_row('array');
    }

    function get_user($userID){
        $this->db->select()->from('users')->where(array('userID'=>$userID));
        $query=$this->db->get();
        return $query->first_row('array');
    }

    function get_users(){
        $userID = $this->session->userdata('userID');
        $this->db->select('firstname','lastname')->from('users')->where('userID',$userID);
        $query = $this->db->get();
        return $query->result_array();
    }

    function insert_post($data){
        $this->db->insert('posts',$data);
        return $this->db->insert_id();
    }

    function update_post($postID,$data){
        $this->db->where('postID',$postID);
        $this->db->update('posts',$data);
    }

    function delete_post($postID){
        $this->db->where('postID',$postID);
        $this->db->delete('posts');
    }
}

和我的代码来自views / post_index.php

<div class="panel">
<?php if (!isset($posts)) { ?>
    <p>There are currently no posts on my blog.</p>
    <?php
} else {
    foreach ($posts as $row) {
        ?>
        <div class="panel-heading">
            <h2 href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>"><?= $row['title'] ?></h2>
        </div>
        <div class="panel-body">
            <p><?= substr(strip_tags($row['post']), 0, 200) . "..." ?></p>
            <br><br>
            <div class="panelver">
                <h6 href="<?= base_url() ?>posts/post/<?= $row['userID'] ?>">Posted by: 
                    <?php
                    if($row['userID'] == 0) {
                        echo "Someone";
                    } else {
                        echo $this->db->select('firstname','lastname')->from('users')->where('userID',$row['userID']);
                    }
                    ?></h6>
                <p href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>">Added last: <?= $row['date_added'] ?></p>
            </div>
            <p><a href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>">Read More</a> - - - <a href="<?= base_url() ?>edit/editpost/<?= $row['postID'] ?>">Edit</a> | <a href="<?= base_url() ?>posts/deletepost/<?= $row['postID'] ?>">Delete</a></p>
            <hr/>
        </div>
        <?php
    }
}
?>
</div>

输出:

Blog Posts

这是一篇文章 blah,blah,blah .....“发布者:”必须使用第一个表中的userID作为输出从第二个表值中输出作者名称获取userID,请帮帮我! T_T ...

发布者:2

最后添加:2014-09-20 11:30:00

阅读更多 - - - 编辑|删除

但是当我这样做时:

<div class="panel">
<?php if (!isset($posts)) { ?>
    <p>There are currently no posts on my blog.</p>
    <?php
} else {
    foreach ($posts as $row) {
        ?>
        <div class="panel-heading">
            <h2 href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>"><?= $row['title'] ?></h2>
        </div>
        <div class="panel-body">
            <p><?= substr(strip_tags($row['post']), 0, 200) . "..." ?></p>
            <br><br>
            <div class="panelver">
                <h6 href="<?= base_url() ?>posts/post/<?= $row['userID'] ?>">Posted by: 
                    <?php
                    if($row['userID'] == 0) {
                        echo "Someone";
                    } else {
                        echo $this->db->select('firstname','lastname')->from('users')->where('userID',$row['userID']);
                    }
                    ?></h6>
                <p href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>">Added last: <?= $row['date_added'] ?></p>
            </div>
            <p><a href="<?= base_url() ?>posts/post/<?= $row['postID'] ?>">Read More</a> - - - <a href="<?= base_url() ?>edit/editpost/<?= $row['postID'] ?>">Edit</a> | <a href="<?= base_url() ?>posts/deletepost/<?= $row['postID'] ?>">Delete</a></p>
            <hr/>
        </div>
        <?php
    }
}
?>
</div>

会发生这种情况:

博客帖子

这是一篇文章 blah,blah,blah .....“发布者:”必须使用第一个表中的userID作为输出从第二个表值中输出作者名称获取userID,请帮帮我! T_T ...

发布者: 遇到PHP错误

严重程度:4096

消息:类CI_DB_mysql_driver的对象无法转换为字符串

文件名:views / post_index.php

行号:42

最后添加:2014-09-20 11:30:00

阅读更多 - - - 编辑|删除

希望大家都了解我的代码结构,更多的帮助将非常感激。 你们这一切都是不可能的!

P.S:我是一名noob程序员,也是CodeIgniter的新手:)

1 个答案:

答案 0 :(得分:0)

Ok。所以我从你的问题得到的是你有两个表,其中userId存储在一个中,用户详细信息存储在另一个中。所以请尝试这个,因为你需要在回显之前获取该行。

echo $this->db->select('firstname','lastname')->from('users')->where('userID',$row['userID'])->get()->row();

上面的代码也可以这样写:

$this->db->select('firstname','lastname')->where('userID',$row['userID'])->get('users')->row();

如果您有任何疑问,请告诉我。