- 2008-04-12 (Sat) 7:00
- Zend_Db
intro
This article illustrates how to save form data with Zend_Db_Table_Row and Zend_Form. You can download the source code of this article from here.
1.Create bootstrap.php and config.ini
Create the file
application/bootstrap.php with the following content.
<?php set_include_path('../library' . PATH_SEPARATOR . get_include_path()); define('APP_BASE', '../application'); define('CONFIG_PATH', APP_BASE . '/config.ini'); require_once 'Zend/Controller/Front.php'; require_once 'Zend/Layout.php'; require_once 'Zend/Db.php'; require_once 'Zend/Config/Ini.php'; require_once 'Zend/Db/Table/Abstract.php'; $layout = Zend_Layout::startMvc(); //$layout->getView()->baseUrl = '/yourBaseUrl'; $config = new Zend_Config_Ini(CONFIG_PATH, 'staging'); $params = $config->database->params->toArray(); $params['options'][Zend_Db::CASE_FOLDING] = Zend_Db::CASE_LOWER; $dbAdapter = Zend_Db::factory($config->database->adapter, $params); Zend_Db_Table_Abstract::setDefaultAdapter($dbAdapter); Zend_Controller_Front::run(APP_BASE . '/controllers');
Create the file application/config.ini with the following content.
Please modify database.params.* properly.
[staging] database.adapter = pdo_mysql database.params.host = localhost database.params.username = db_user database.params.password = db_password database.params.dbname = db_name
In this article, we will use the following sql.
CREATE TABLE profiles ( id integer AUTO_INCREMENT NOT NULL PRIMARY KEY, user_id integer NOT NULL, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, email varchar(200) NOT NULL, url varchar(200) NOT NULL );
2.Create DAO with Zend_Db_Table
Create the file
application/models/Profiles.php with the following content.
<?php require_once 'Zend/Db/Table/Abstract.php'; require_once 'Zend/Form.php'; class Profiles extends Zend_Db_Table_Abstract { protected $_name = 'profiles'; public function getForm() { $form = new Zend_Form(); $first_name = $form->createElement('text', 'first_name'); $first_name->setLabel('First Name') ->setRequired(true) ->addFilter('stringTrim') ->addValidator('stringLength', false, array(1,100)); $last_name = $form->createElement('text', 'last_name'); $last_name->setLabel('Last Name') ->setRequired(true) ->addFilter('stringTrim') ->addValidator('stringLength', false, array(1,100)); $email = $form->createElement('text', 'email'); $email->setLabel('E-Mail') ->setRequired(true) ->addFilter('stringTrim') ->addValidator('emailAddress', false) ->addValidator('stringLength', false, array(1,200)); $url = $form->createElement('text', 'url'); $url->setLabel('URL') ->setRequired(false) ->addFilter('stringTrim') ->addValidator('stringLength', false, array(1,200)); $form->addElements(array( $first_name, $last_name, $email, $url )); return $form; } public function findByUserId($user_id) { $select = $this->select()->where('user_id = ?', $user_id); return $this->fetchAll($select); } }
3.Create Controller
Create the file
application/constorllers/IndexController.php with the following content.
<?php require_once 'Zend/Controller/Action.php'; require_once APP_BASE . '/models/Profiles.php'; class IndexController extends Zend_Controller_Action { protected $_user_id = 1; protected function prepareForm($form) { $form->setAction($this->_request->getBaseUrl() . '/index/index') ->setMethod('post'); $submit = $form->createElement('submit', 'save'); $submit->setLabel('Save'); $form->addElement($submit); return $form; } public function indexAction() { $profiles = new Profiles(); $row =$profiles->findByUserId($this->_user_id)->current(); if (!$row) { $row = $profiles->createRow(array('user_id' => $this->_user_id)); } $form = $profiles->getForm(); if ($this->getRequest()->isPost()) { if ($form->isValid($_POST)) { // save profile $row->setFromArray($form->getValues()); $row->save(); } } else { // set default values $form->setDefaults($row->toArray()); } $this->view->form = $this->prepareForm($form); } }
4.Create View
Create the file
application/views/scripts/index/index.phtml with the following content.
<h1><?= $this->translate('Your Profile') ?></h1> <?= $this->form ?>
5.Check
Let's access the web server and check that the form data is stored.
References
The following is about generation of Zend_Form from table information.
Comments:0
Trackbacks:0
- Trackback URL for this entry
- http://www.oplabo.com/article/19/trackback
- Listed below are links to weblogs that reference
- Saving Data using Zend_Db_Table from Open Programming Laboratory