2

codeigniterを使用して簡単な調査アプリケーションをコーディングしようとしています。すべての回答にチェックボックスがあり、すべての回答をデータベースのテーブルに保存したいです。質問したいのは、このすべての情報をどのように保存するかです。表私はコーディングの世界に不慣れで、簡単な解決策で十分です。今私が持っているのは、ここで設定されたビューだけです。

<html>
 <body>

<?php form_open('survay'); ?>  
<?php foreach($survay_data as $survay):?> 
<ul>
    <li><h1><?php echo $survay->Question; ?></h1></li> 
    <li><?php echo $survay->qA; ?><input type="checkbox"  name = "q1" value = "qA"></li>
    <li><?php echo $survay->qB; ?><input type="checkbox"  name = "q2" value = "qB"></li>
    <li><?php echo $survay->qC; ?><input type="checkbox"  name = "q3" value = "qC"></li>
<?php endforeach; ?>
<input type="textarea" value='a' name="comment">
<br>
<input type="submit" value="Submit">
</ul>
</body>
</html>
4

1 に答える 1

1

ここで答えを見つけます:https ://stackoverflow.com/a/15086172/827224

これはあなたが望むことをするはずです。Stackoverでのチャットに基づいて、回答が提供されました。あなたの質問はあなたがチャットで行った要求ほど明確ではありません。問題を解決できるコードを以下で見つけてください

CODEIGNITERの基本的な使用法:

コメントの量を減らすために、このコードを提供しています。あなたがCodeigniterにかなり慣れていないことは確かです。私はできる限り助けることができます。

ステップ1:データベース

データベーステーブル「tblquestions」を作成します。フィールドはQID、qA、qB、およびqCである必要があります。たくさんある場合は、最大43のようなレコードをフィールドに入力します。わずか5レコードで十分です。

ステップ2:モデル

<?php

class Survay extends CI_Model {

    function dosurvay($question_id = null) {

        $this->db->select('QID, Question, qA, qB, qC');
        $this->db->from('tblquestions');
        if ($question_id) {
            $this->db->where('QID', $question_id);
        }
        $this->db->limit(1);
        $query = $this->db->get();

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

 function addsurvay($arrData) {

    $this->db->insert('tblanswers', $arrData);

    if ($this->db->affected_rows() > 0) {
        return $this->db->insert_id();
    } else {
        return false;
    }
}

}
?>

ステップ3:コントローラー

<?php

class Survaycontroller extends CI_Controller {

    // 'QID, Question, qA, qB, qC'
    function __construct() {
        parent::__construct();
        $this->load->model('survay');
    }

    function index() {
        //This should select the survey question
        $data = array();
        $question_id = $this->uri->segment(3);
        $data[survay_data] = $this->survay->dosurvay($question_id);
        $this->load->view('survay_view', $data);
    }

    function addanswer() {
        //The answer is submitted to this...
        $arrData = array();
        $userid = null;
        if ($this->session->userdata("userid")) {
            $userid = $this->session->userdata("userid");
        }
        if ($this->input->post()) {
            $arrData["answerid"] = $this->input->post("QID");
            $arrData["questionid"] = $this->input->post("qA");
            if ($this->input->post("qA")) {
                $arrData["answerA"] = $this->input->post("qA");
            }
            if ($this->input->post("qB")) {
                $arrData["answerB"] = $this->input->post("qB");
            }
            if ($this->input->post("qC")) {
                $arrData["answerC"] = $this->input->post("qC");
            }
            $arrData["userid"] = $userid;
        }
        $viewData[survay_data_id] = $this->survay->addsurvay($arrData); //Get the ID of the answer stored
        $this->load->view('survay_view', $viewData);
    }

}
?>

ステップ4:ビュー

<?php if(isset($survay_data)) : ?>
<form action="http://localhost/Surva/index.php/survaycontroller/addanswer/" name="myform" id="myform" method="post">
   <?php foreach ($survay_data as $survay): ?> 
        <ul>
            <li><h1><?php echo $survay->Question; ?></h1></li> 
            <li><?php echo $survay->qA; ?><input type="checkbox" name="qA" value="<?php echo $survay->qA; ?>"></li>
            <li><?php echo $survay->qB; ?><input type="checkbox" name="qB" value="<?php echo $survay->qA; ?>"></li>
            <li><?php echo $survay->qC; ?><input type="checkbox" name="qC" value="<?php echo $survay->qA; ?>"></li>
            <li><input type="hidden" name="QID" value="<?php echo $survay->QID; ?>"></li>
            <li><input type="submit" name="btn" value="Answer"></li>
        </ul>
    <?php endforeach; ?>
</form>
<?php endif; ?>

試して:

http://localhost/Surva/index.php/survaycontroller/index/2

質問番号2を取得するには

これで確実に機能します。すでに持っているものをすべて交換してください。これらの新しいコードセットが、上記のコードセットをより効率的に置き換えるかどうかを教えてください。

于 2013-02-27T12:58:52.010 に答える