Zend Framework教程之連接數(shù)據(jù)庫(kù)并執(zhí)行增刪查的方法(附demo源碼下載)
本文實(shí)例講述了Zend Framework教程之連接數(shù)據(jù)庫(kù)并執(zhí)行增刪查的方法。分享給大家供大家參考,具體如下:
我們先要在數(shù)據(jù)庫(kù)里建立一個(gè)叫message的表,它有三個(gè)字段.分別為id,title,content.其中id為主鍵.
現(xiàn)在我們開(kāi)始第一步:在application文件夾下面加入一個(gè)config文件夾,并在這里面增加一個(gè)config.ini文件..這里面是配置數(shù)據(jù)庫(kù)基本信息.
如下代碼所示:
[general] db.adapter=PDO_MYSQL //請(qǐng)開(kāi)啟PDO擴(kuò)展 db.config.host=localhost //Mysql主機(jī) db.config.username=root //用戶(hù)名 db.config.password= //密碼,我這里為空 db.config.dbname=zendoophp //數(shù)據(jù)庫(kù)名
第二步:在application下的models文件夾下增加一個(gè)Message.php文件..這里命名是以數(shù)據(jù)表名稱(chēng)相同.
<?php class Message extends Zend_Db_Table { protected $_name ="message"; protected $_primary = 'id'; }
第三步:接下來(lái)..我們要在我們的入口文件index.php里加入下面代碼如下:
//配置數(shù)據(jù)庫(kù)參數(shù),并連接數(shù)據(jù)庫(kù) $config=new Zend_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('SET NAMES UTF8'); Zend_Db_Table::setDefaultAdapter($dbAdapter); Zend_Registry::set('dbAdapter',$dbAdapter);
第四步:我們就要對(duì)我們的IndexController.php控制器進(jìn)行操作了..分別有四個(gè)方法.它們的作用就是增加數(shù)據(jù),修改,
刪除數(shù)據(jù).程序如下..(我在程序員都有注解.這里不就多說(shuō)!):
class IndexController extends Zend_Controller_Action { function init() { $this->registry = Zend_Registry::getInstance(); $this->view = $this->registry['view']; $this->view->baseUrl = $this->_request->getBaseUrl(); } function indexAction() { $message=new message();//實(shí)例化數(shù)據(jù)庫(kù)類(lèi) //這里給變量賦值,在index.phtml模板里顯示 $this->view->bodyTitle = 'Hello World!'; //取到所有數(shù)據(jù).二維數(shù)組 $this->view->messages=$message->fetchAll()->toArray(); //print_r( $this->view->messages); echo $this->view->render('index.phtml');//顯示模版 } function addAction(){ //如果是POST過(guò)來(lái)的值.就增加.否則就顯示增加頁(yè)面 if(strtolower($_SERVER['REQUEST_METHOD'])=='post'){ //過(guò)濾一些數(shù)據(jù).不過(guò)這里還有檢測(cè)一些動(dòng)作沒(méi)有做.. //請(qǐng)大家加了..我就不多寫(xiě)那么多了.時(shí)間關(guān)系.. Zend_Loader::loadClass('Zend_Filter_StripTags'); $filter=new Zend_Filter_StripTags(); $content=$filter->filter(($this->_request->getPost('content'))); $title=$filter->filter(($this->_request->getPost('title'))); $message=new Message(); $data=array( 'content'=>$content, 'title'=>$title ); $message->insert($data); unset($data); echo '您增加數(shù)據(jù)成功!請(qǐng)您 $this->view->baseUrl.'/index/index/">返回'; }else{ echo $this->view->render('add.phtml');//顯示增加模版 } } public function editAction(){ $message=new Message(); $db = $message->getAdapter(); Zend_Loader::loadClass('Zend_Filter_StripTags'); $filter=new Zend_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); //更新表數(shù)據(jù) $message->update($set, $where) unset($set); echo '您修改數(shù)據(jù)成功!請(qǐng)您 $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');//顯示編輯模版 } } public function delAction() { $message=new Message(); //能過(guò)ID刪除數(shù)據(jù).這里有一些動(dòng)作沒(méi)有做.比如說(shuō)沒(méi)有ID頁(yè)面要去哪里. //.我只是給大家一個(gè)思想..所以不會(huì)那么完整 $id = (int)$this->_request->getParam('id'); if ($id > 0) { $where = 'id = ' . $id; $message->delete($where); } echo '您刪除數(shù)據(jù)成功!請(qǐng)您 $this->view->baseUrl.'/index/index/">返回'; } }
第五步:就是增加對(duì)應(yīng)的View.也就是網(wǎng)頁(yè)模板..分別是add.phtml,edit.phtml,index.phtml.這在程序里也有注解.請(qǐng)大家下載文件運(yùn)行查看.
完整實(shí)例代碼點(diǎn)擊此處本站下載。
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Zend FrameWork框架入門(mén)教程》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《Yii框架入門(mén)及常用技巧總結(jié)》、《ThinkPHP入門(mén)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Zend Framework框架的PHP程序設(shè)計(jì)有所幫助。
- Zend Framework 2.0事件管理器(The EventManager)入門(mén)教程
- Zend Framework數(shù)據(jù)庫(kù)操作技巧總結(jié)
- Zend Framework數(shù)據(jù)庫(kù)操作方法實(shí)例總結(jié)
- Zend Framework入門(mén)教程之Zend_Db數(shù)據(jù)庫(kù)操作詳解
- ZendFramework框架實(shí)現(xiàn)連接兩個(gè)或多個(gè)數(shù)據(jù)庫(kù)的方法
- Zend Framework連接Mysql數(shù)據(jù)庫(kù)實(shí)例分析
- 解析如何使用Zend Framework 連接數(shù)據(jù)庫(kù)
- zend framework配置操作數(shù)據(jù)庫(kù)實(shí)例分析
- windows下zendframework項(xiàng)目環(huán)境搭建(通過(guò)命令行配置)
- zend framework多模塊多布局配置
- Zend Framework開(kāi)發(fā)入門(mén)經(jīng)典教程
- ZendFramework2連接數(shù)據(jù)庫(kù)操作實(shí)例
相關(guān)文章
php使用lua+redis實(shí)現(xiàn)限流,計(jì)數(shù)器模式,令牌桶模式
這篇文章主要介紹了php使用lua+redis實(shí)現(xiàn)限流,計(jì)數(shù)器模式,令牌桶模式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04PHP實(shí)現(xiàn)頁(yè)面靜態(tài)化的超簡(jiǎn)單方法
下面小編就為大家?guī)?lái)一篇PHP實(shí)現(xiàn)頁(yè)面靜態(tài)化的超簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09一個(gè)簡(jiǎn)單的網(wǎng)頁(yè)密碼登陸php代碼
密碼對(duì),就可以看到指定內(nèi)容, 密碼不對(duì)就進(jìn)不去2012-07-07WAMP環(huán)境中擴(kuò)展oracle函數(shù)庫(kù)(oci)
本文給大家介紹的是在windows環(huán)境下為php環(huán)境擴(kuò)展Oracle函數(shù)庫(kù)的過(guò)程,十分的詳細(xì),有需要的小伙伴可以參考下。2015-06-06PHP實(shí)現(xiàn)微信提現(xiàn)(企業(yè)付款到零錢(qián))
這篇文章主要為大家詳細(xì)介紹了PHP實(shí)現(xiàn)微信提現(xiàn),企業(yè)付款到零錢(qián),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08thinkphp 5框架實(shí)現(xiàn)登陸,登出及session登陸狀態(tài)檢測(cè)功能示例
這篇文章主要介紹了thinkphp 5框架實(shí)現(xiàn)登陸,登出及session登陸狀態(tài)檢測(cè)功能,結(jié)合實(shí)例形式分析了thinkPHP5登陸判斷、跳轉(zhuǎn)及session的相關(guān)使用技巧,需要的朋友可以參考下2019-10-1050個(gè)優(yōu)秀經(jīng)典PHP算法大集合 附源碼
這篇文章主要介紹了50個(gè)優(yōu)秀經(jīng)典PHP算法大集合 附源碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08php循環(huán)table實(shí)現(xiàn)一行兩列顯示的方法
這篇文章主要介紹了php循環(huán)table實(shí)現(xiàn)一行兩列顯示的方法,本文直接給出實(shí)現(xiàn)代碼,重點(diǎn)就是在取余方法的運(yùn)用,需要的朋友可以參考下2015-06-06