Zend Framework教程之连接数据库并执行增删查的方法(附demo源码下载)

6年以前  |  阅读数:989 次  |  编程语言:PHP 

本文实例讲述了Zend Framework教程之连接数据库并执行增删查的方法。分享给大家供大家参考,具体如下:

我们先要在数据库里建立一个叫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控制器进行操作了..分别有四个方法.它们的作用就是增加数据,修改,

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


    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 = 'Hello World!'; 
      //取到所有数据.二维数组 
      $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 '您增加数据成功!请您 
     $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); 
     //更新表数据 
     $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');//显示编辑模版 
       } 
     } 
    public function delAction() 
    { $message=new Message(); 
     //能过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相关内容感兴趣的读者可查看本站专题:《Zend FrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Zend Framework框架的PHP程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
文件下载
获取IMEI
贪吃蛇
双位运算符
发送邮件
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
提取后缀名
年的日历图
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例