从数据库填充下拉列表

时间:2013-12-17 16:34:55

标签: php mysql database forms

我正在尝试使用数据库中的数据填充表单上的下拉列表,我尝试了以下但是没有成功它给了我一个意外的错误;我试过删除但仍然出错?

 echo form::label('myproduct', 'My Product:');
         echo form::select('form[myproduct]', $sql = mysql_query("SELECT description FROM claim_incentive"); while ($row = mysql_fetch_array($sql))
            {echo "<option value=\"1\">" . $row['description'] . "</option>"; }

我想我可能会将代码放在错误的位置,因为我有两个php文件,一个是控制器,我的代码如下:

public function action_claimincentive() {
                    $this->template->content = View::factory('crm/uk/claim_incentive_form');
                    $this->template->content->thanks = false;
                    $this->template->content->val = '';
                    $this->template->content->post = '';

                        if ($this->request->post('form')) {
                                    $post = $this->request->post('form');

                                    $stmt = DB::query(Database::INSERT, 'INSERT INTO `claim_incentive_form_data` (`User Reference`, `Claimant Postcode`, `Purchase Order No.`, `Claimant Email Address`, `Storename`, `Storetown`, `Date of Sale`, `Date of Delivery`, `Acknowledgement No.`, `Product`)
                                                                        VALUES (:userreference, :claimantpostcode, :orderno, :email, :storename, :storetown, :dateofsale, :dateofdelivery, :acknowledgementno, :product)');
                                    $stmt->param(':userreference', $post['userreference']);
                                    $stmt->param(':claimantpostcode', $post['claimantpostcode']);
                                    $stmt->param(':orderno', $post['orderno']);
                                    $stmt->param(':email', $post['email']);
                                    $stmt->param(':storename', $post['storename']);
                                    $stmt->param(':storetown', $post['storetown']);
                                    $stmt->param(':dateofsale', $post['dateofsale']);
                                    $stmt->param(':dateofdelivery', $post['dateofdelivery']);
                                    $stmt->param(':acknowledgementno', $post['acknowledgementno']);
                                    $stmt->param(':product', $post['product']);
                                        try {
                                                $stmt->execute();
                                                $this->template->content->post = $post;
                                                $this->template->content->thanks = true;
                                                } catch (Exception $e) {
                                                    FB::error($e);
                                                }

                    }
                }

另一个是实际形式,请参阅下面的部分内容:

echo form::label('dateofdelivery', 'Date of Delivery:');
         echo form::input('form[dateofdelivery]', $val, array('class'=>'input', 'id'=>'dateofdelivery'));

         echo form::label('acknowledgementno', 'Acknowledgement No:');
         echo form::input('form[acknowledgementno]', $val, array('class'=>'input', 'id'=>'acknowledgementno'));

         echo form::label('product', 'Product:');
         echo form::select('form[product]', array(
                                            '' => 'Please select from the list',
                                            'In store' => 'In store',
                                            'Word of mouth' => 'Word of mouth',
                                            'Television' => 'Television',
                                            'Newspaper' => 'Newspaper',
                                            'Magazine' => 'Magazine',
                                            'Internet' => 'Internet',
                                            'Google Reasearch' => 'Google Reasearch',
                                            'Radio' => 'Radio',
                                            'Medical Recommendation' => 'Medical Recommendation',
                            ), '', array('class="select"', 'id'=>'product'));

        echo form::submit('btnSubmit', 'Submit', array('id'=>'btnSubmit', 'class'=>'button'));
        echo '</div>';
        echo '<div class="clearfix"></div>';

        echo form::close();

1 个答案:

答案 0 :(得分:0)

你的标记中有一些错误,让我们看看:

在这一行中你有一些错误:

echo form::select('form[myproduct]', $sql = mysql_query("SELECT description FROM claim_incentive");

您正在打开两个括号,但只关闭一个应该是:

echo form::select('form[myproduct]', $sql = mysql_query("SELECT description FROM claim_incentive"));

没有必要在方法中分配sql变量,我不知道你使用哪种框架,所以我只注意语法错误。