[ZendFramework教程>>原创作品]

2.初级篇:Zend Framework 怎样连接数据库并执行增,删,查,改?

  • 时间:2008年10月19日 22:00:56
  • 浏览量:6566
  • 评论量:39
  • 作者:kylingood

接着我来给大家讲第二篇的教程.有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教程..我就不在这里浪费时间了...
文件下载地址:源码下载
  希望大家给我留言...谢谢...

原创文章如转载,请注明:转载OOPHP开源博客 [ http://www.oophp.cn/ ]

上一篇:[转]一个用php写的中文分词类 下一篇:[转]何为SNS? SNS是怎样的概念...

: Baidu搜藏 QQ书签 Google书签 Del.icio.us POCO网摘 Yahoo书签 新浪ViVi 365Key网摘 天极网摘 和讯网摘 Windows Live 提交新发现,Dig it

用户推荐文章
相关文章
网友评论
发表评论

会员的头像

: 请选个帅照吧!
:  *  尊姓大名大名(2-30字).
:  *  来了就多说几句吧(4-250字)
:  *  没办法,只为防机器人@_@