我正在尝试使用表单从数据库中填充它,用户可以编辑信息。我添加了名为"编号"的模型:
Number.php:
<?php
class Model_Number extends Zend_Db_Table_Abstract
{
protected $_name = 'cc_number';
protected $_schema = 'general';
}
在这个表(cc_number)中,我有三个字段:"id,number,country"
在申请/表格中,我添加了以下表格:
EditNumber.php:
<?php
Class Form_EditNumber extends Zend_Form
{
public function __construct($option = null)
{
parent::__construct($option);
$this->setName('edit_number');
$message = new Zend_Form_Element_Text('message');
$message->setLabel(' number :')
->setRequired(true);
$country = new Zend_Form_Element_Text('country');
$country->setLabel(' country name :')
->setRequired(true);
$login = new Zend_Form_Element_Submit('login');
$login ->setLabel('edit ');
$this ->addElements(array($message,$login));
$this->setMethod('post');
}
}
在控制器中,我尝试从URL的最后一部分获取数字,然后从这个数字中获取信息:
编号/编辑操作:
public function editAction(){
$request = $this->getRequest();
$form_number = new Form_EditNumber();
$uri = Zend_Controller_Front::getInstance()->getRequest()->getRequestUri();
$part = basename($uri);
$numberModel = new Model_Number();
$select = $numberModel->fetchRow($numberModel->select()->where("number = '$part'"));
$this->view->edit_form = $form_number->populate($select->toArray());
}
我不会以这种方式从Uri获取$part
。它应该来自请求的$_GET
部分
你能print_r
Zend_Controller_Front::getInstance()->getRequest()
的内容吗?因为那样你可能会得到$part
。
要从请求中获取值,请在控制器中使用$this->getRequest()->getParam('ParamName');
,其中ParamName
是带有所需数字的最后一个参数的名称。
$part = $this->getRequest()->getParam('ParamName');
然后在查询中,您需要像这样传递这个值:
$select = $numberModel->fetchRow($numberModel->select()->where("number = ". $part));
提示:最好使用PDO