Zend Framework教程之连接数据库并执行增删查的方法(附demo源码下载)
本文实例讲述了ZendFramework教程之连接数据库并执行增删查的方法。分享给大家供大家参考,具体如下:
我们先要在数据库里建立一个叫message的表,它有三个字段.分别为id,title,content.其中id为主键.
现在我们开始第一步:在application文件夹下面加入一个config文件夹,并在这里面增加一个config.ini文件..这里面是配置数据库基本信息.
如下代码所示:
[general] db.adapter=PDO_MYSQL//请开启PDO扩展 db.config.host=localhost//Mysql主机 db.config.username=root//用户名 db.config.password=//密码,我这里为空 db.config.dbname=zendoophp//数据库名
第二步:在application下的models文件夹下增加一个Message.php文件..这里命名是以数据表名称相同.
<?php classMessageextendsZend_Db_Table{ protected$_name="message"; protected$_primary='id'; }
第三步:接下来..我们要在我们的入口文件index.php里加入下面代码如下:
//配置数据库参数,并连接数据库 $config=newZend_Config_Ini('./application/config/config.ini',null,true); Zend_Registry::set('config',$config); $dbAdapter=Zend_Db::factory($config->general->db->adapter, $config->general->db->config->toArray()); $dbAdapter->query('SETNAMESUTF8'); Zend_Db_Table::setDefaultAdapter($dbAdapter); Zend_Registry::set('dbAdapter',$dbAdapter);
第四步:我们就要对我们的IndexController.php控制器进行操作了..分别有四个方法.它们的作用就是增加数据,修改,
删除数据.程序如下..(我在程序员都有注解.这里不就多说!):
classIndexControllerextendsZend_Controller_Action { functioninit() { $this->registry=Zend_Registry::getInstance(); $this->view=$this->registry['view']; $this->view->baseUrl=$this->_request->getBaseUrl(); } functionindexAction() { $message=newmessage();//实例化数据库类 //这里给变量赋值,在index.phtml模板里显示 $this->view->bodyTitle='HelloWorld!'; //取到所有数据.二维数组 $this->view->messages=$message->fetchAll()->toArray(); //print_r($this->view->messages); echo$this->view->render('index.phtml');//显示模版 } functionaddAction(){ //如果是POST过来的值.就增加.否则就显示增加页面 if(strtolower($_SERVER['REQUEST_METHOD'])=='post'){ //过滤一些数据.不过这里还有检测一些动作没有做.. //请大家加了..我就不多写那么多了.时间关系.. Zend_Loader::loadClass('Zend_Filter_StripTags'); $filter=newZend_Filter_StripTags(); $content=$filter->filter(($this->_request->getPost('content'))); $title=$filter->filter(($this->_request->getPost('title'))); $message=newMessage(); $data=array( 'content'=>$content, 'title'=>$title ); $message->insert($data); unset($data); echo'您增加数据成功!请您 $this->view->baseUrl.'/index/index/">返回'; }else{ echo$this->view->render('add.phtml');//显示增加模版 } } publicfunctioneditAction(){ $message=newMessage(); $db=$message->getAdapter(); Zend_Loader::loadClass('Zend_Filter_StripTags'); $filter=newZend_Filter_StripTags(); //同上面addAction if(strtolower($_SERVER['REQUEST_METHOD'])=='post'){ $content=$filter->filter(($this->_request->getPost('content'))); $title=$filter->filter(($this->_request->getPost('title'))); $id=$filter->filter(($this->_request->getPost('id'))); $set=array( 'content'=>$content, 'title'=>$title ); $where=$db->quoteInto('id=?',$id); //更新表数据 $message->update($set,$where) unset($set);echo'您修改数据成功!请您 $this->view->baseUrl.'/index/index/">返回'; }else{ $id=$filter->filter(($this->_request->getParam('id'))); $this->view->messages=$message->fetchAll('id='.$id)->toArray(); echo$this->view->render('edit.phtml');//显示编辑模版 } } publicfunctiondelAction() {$message=newMessage(); //能过ID删除数据.这里有一些动作没有做.比如说没有ID页面要去哪里. //.我只是给大家一个思想..所以不会那么完整 $id=(int)$this->_request->getParam('id'); if($id>0){ $where='id='.$id; $message->delete($where); } echo'您删除数据成功!请您 $this->view->baseUrl.'/index/index/">返回'; } }
第五步:就是增加对应的View.也就是网页模板..分别是add.phtml,edit.phtml,index.phtml.这在程序里也有注解.请大家下载文件运行查看.
完整实例代码点击此处本站下载。
更多关于zend相关内容感兴趣的读者可查看本站专题:《ZendFrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于ZendFramework框架的PHP程序设计有所帮助。