热烈祝贺台州朗动科技的站长论坛隆重上线!(2012-05-28)    热烈庆祝伟大的祖国60周年生日 点击进来我们一起为她祝福吧(2009-09-26)    站长论坛禁止发布广告,一经发现立即删除。谢谢各位合作!.(2009-08-08)    热烈祝贺台州网址导航全面升级,全新版本上线!希望各位一如既往地支持台州网址导航的发展.(2009-03-28)    台州站长论坛恭祝各位新年快乐,牛年行大运!(2009-01-24)    台州Link正式更名为台州网址导航,专业做以台州网址为主的网址导航!(2008-05-23)    热烈祝贺台州Link资讯改名为中国站长资讯!希望在以后日子里得到大家的大力支持和帮助!(2008-04-10)    热烈祝贺台州Link论坛改名为台州站长论坛!希望大家继续支持和鼓励!(2008-04-10)    台州站长论坛原[社会琐碎]版块更名为[生活百科]版块!(2007-09-05)    特此通知:新台州站长论坛的数据信息全部升级成功!">特此通知:新台州站长论坛的数据信息全部升级成功!(2007-09-01)    台州站长论坛对未通过验证的会员进行合理的清除,请您谅解(2007-08-30)    台州网址导航|上网导航诚邀世界各地的网站友情链接和友谊联盟,共同引领网站导航、前进!(2007-08-30)    禁止发广告之类的帖,已发现立即删除!(2007-08-30)    希望各位上传与下载有用资源和最新信息(2007-08-30)    热烈祝贺台州站长论坛全面升级成功,全新上线!(2007-08-30)    
便民网址导航,轻松网上冲浪。
台州维博网络专业开发网站门户平台系统
您当前的位置: 首页 » PHP/Perl编程 » Zend Framework怎样连接数据库并执行增删查改

Zend Framework怎样连接数据库并执行增删查改

论坛链接
  • Zend Framework怎样连接数据库并执行增删查改
  • 发布时间:2009-07-29 14:16:57    浏览数:8562    发布者:superadmin    设置字体【   
接着我来给大家讲第二篇的教程.有PHPer也给我提建议说这方面的太基础的东西没有多大作用.希望我可以写一些高级一点的教程..但是我自己的技术水平也就这个样子.
自己都不知道高级的是怎样一个方面..所以没有办法去达到大家的建议..同时也有PHPer说不如就我自己的博客作来案例来分析..这样也是可行的..我想也是,不过大家要是基础都没有
怎么可能会写一个博客呢?到时候只会有一堆的问题来问..所以我还是把这一系列教程给写完..要是有时间..再就我的博客作为案例来讲解..希望可以帮上一些初学者.
好了,言规正传....我开始讲第二篇教程了...
我们接着上一篇的教程,项目的结构目录不变...我们先要在数据库里建立一个叫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
class Message extends Zend_Db_Table

{
protected §_name ="message";
protected §_primary = 'id';
}第三步:接下来..我们要在我们的入口文件index.php里加入下面代码如下:

//配置数据库参数,并连接数据库
$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);第四步:我们就要对我们的IndexController.php控制器进行操作了..分别有四个方法.它们的作用就是增加数据,修改,

删除数据.程序如下..(我在程序员都有注解.这里不就多说!):

<?php
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();//实例化数据库类
//这里给变量赋值,在index.phtml模板里显示
$this->view->bodyTitle = '<h1>Hello World!</h1>';
//取到所有数据.二维数组
$this->view->messages=$message->fetchAll()->toArray();
//print_r( $this->view->messages);
echo $this->view->render('index.phtml');//显示模版
}

function addAction(){
//如果是POST过来的值.就增加.否则就显示增加页面
if(strtolower(§_SERVER['REQUEST_METHOD'])=='post'){
//过滤一些数据.不过这里还有检测一些动作没有做..//请大家加了..我就不多写那么多了.时间关系..
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 '您增加数据成功!请您 <a href="'.$this->view->baseUrl.'/index/index/">返回</a>';

}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);
//更新表数据
$message->update($set, $where)
unset($set); echo '您修改数据成功!请您 <a href="'.$this->view->baseUrl.'/index/index/">返回</a>';

}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();
//能过ID删除数据.这里有一些动作没有做.比如说没有ID页面要去哪里.
//.我只是给大家一个思想..所以不会那么完整
$id = (int)$this->_request->getParam('id');
if ($id > 0) {
$where = 'id = ' . $id;
$message->delete($where);
}
echo '您删除数据成功!请您 <a href="'.$this->view->baseUrl.'/index/index/">返回</a>';

}
}
第五步:就是增加对应的View.也就是网页模板..分别是add.phtml,edit.phtml,index.phtml.这在程序里也有注解.请大家下载文件运行查看.

OK!第二篇教程写完...只有一个查没有写..我想这个可以给PHPer自己来写..因为我后期会写Zend_Search_Lucene教程..我就不在这里浪费时间了...
文件下载地址:源码下载
娱乐休闲专区A 影视预告B 音乐咖啡C 英语阶梯D 生活百科
网页编程专区E AMPZF HTMLG CSSH JSI ASPJ PHPK JSPL MySQLM AJAX
Linux技术区 N 系统管理O 服务器架设P 网络/硬件Q 编程序开发R 内核/嵌入
管理中心专区S 发布网址T 版主议事U 事务处理