簡體   English   中英

codeigniter:使用會話從另一個表更新表

[英]codeigniter: Update table from another table with session

我在更新表時遇到了一些挑戰,該表與來自另一個表的會話userdata聯接在一起。 每次運行時,它都會顯示未定義的函數。 請讓我知道我在哪里弄錯了,可以解決它。請抽出時間查看它,我是新手。 這是控制器

 public function index()
    {

        if ( $this->session->userdata('logged_in') )
        {

            $id = $this->session->userdata('id');
            $this->load->model('Userinfo_model');
            $data['result'] = $this->Userinfo_model->get_users($id);

            $this->load->view("usermain_info", $data);

        }
    }
    public function update_user (){
        $data = $this->input->post('userId');
        $id = array(
            'balance' => $this->input->post('balance'),
            'id' => $this->input->post('id')
        );
        $this->Userinfo_model->update_user($id, $data);
        $this->index();
    }

模型

function get_users($userid)
    {

        if (isset($this->session->userdata['logged_in'])) {

            $userid = ($this->session->userdata['logged_in']['id']);
        } else {
            header("location: nwpgroup/nwp2/index.php");
        }

        /* all the queries relating to the data we want to retrieve will go in here. */

        $query = $this->db->query("SELECT * FROM walletbalance WHERE userId='$userid'");


        return $query;
    }
    function update_user($id,$data){
        if (isset($this->session->userdata['logged_in'])) {

            $data = ($this->session->userdata['logged_in']['id']);
        } else {
            header("location: nwpgroup/nwp2/index.php");
        }
        $this->db->where('userId', $data);
        $this->db->update('walletbalance', $id);
    }

視圖

<form method="post" action="<?php echo base_url() . "index.php/userinfo/update_user"?>">
            <?php if($result->num_rows() == 0){
                echo 'No user found';
            }
            else {
                foreach ( $result->result_array() as $new_user ){ ?>
                    <h4>Your name:<input value=" <?php echo $new_user['balance'] ?>" type="text" /> </h4><br />
                    <h4>Your name:<input value=" <?php echo $new_user['id'] ?>" type="text"/> </h4><br/>
                    <h4>Your name: <input value="<?php echo $new_user['userId'] ?>" type="hidden"/> </h4>
                    <input type="submit" id="submit" name="dsubmit" value="Update">
                <?php   }
            }
            ?>

錯誤信息

Message: Undefined property: Userinfo::$Userinfo_model

Message: Call to a member function update_user() on null

謝謝,我很感激

update_user函數中,沒有包含usermain_info模型。 這就是錯誤即將來臨的原因。 請創建構造函數並在其中包含模型。 我已經更新了您的代碼。 試試這個。

<?php    
    function __construct() {
        parent::__construct();
        $this->load->library('session');
        $this->load->model('Userinfo_model');
    }
    public function index(){
        if ( $this->session->userdata('logged_in') ){
            $id = $this->session->userdata('id');            
            $data['result'] = $this->Userinfo_model->get_users($id);
            $this->load->view("usermain_info", $data);
        }
    }
    public function update_user (){
        $data = $this->input->post('userId');
        $id = array(
            'balance' => $this->input->post('balance'),
            'id' => $this->input->post('id')
        );
        $this->Userinfo_model->update_user($id, $data);
        $this->index();
    }

?>

更改您的視圖,如下所示:

<form method="post" action="<?php echo base_url() . "index.php/userinfo/update_user"?>">
        <?php if($result->num_rows() == 0){
            echo 'No user found';
        }
        else {
            foreach ( $result->result_array() as $new_user ){ ?>
                <h4>Your name:<input value=" <?php echo $new_user['balance'] ?>" type="text" name="balance" /> </h4><br />
                <h4>Your name:<input value=" <?php echo $new_user['id'] ?>" type="text" name="id" /> </h4><br/>
                <h4>Your name: <input value="<?php echo $new_user['userId'] ?>" type="hidden" name="userId"/> </h4>
                <input type="submit" id="submit" name="dsubmit" value="Update">
            <?php   }
        }
     ?>
</form>

僅當元素具有名稱時,表單才會將數據發送到服務器

並且您不能多次提交表單。 上面的代碼將為每一行創建更新按鈕。 因此,如果要一次更新所有記錄,請在codeigniter中使用update_batch() 並更改視圖,如下所示:

foreach ( $result->result_array() as $new_user ){ ?>
                <h4>Your name:<input value=" <?php echo $new_user['balance'] ?>" type="text" name="balance" /> </h4><br />
                <h4>Your name:<input value=" <?php echo $new_user['id'] ?>" type="text" name="id" /> </h4><br/>
                <h4>Your name: <input value="<?php echo $new_user['userId'] ?>" type="hidden" name="userId"/> </h4>

            <?php   } ?>
<input type="submit" id="submit" name="dsubmit" value="Update">

供參考: https : //www.codeigniter.com/userguide3/database/query_builder.html#updating-data

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM