侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

数据库  /  管理员 发布于 6年前   183

本文实例讲述了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文件..这里命名是以数据表名称相同.

第三步:接下来..我们要在我们的入口文件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程序设计有所帮助。

您可能感兴趣的文章:

  • Zend Framework 2.0事件管理器(The EventManager)入门教程
  • Zend Framework数据库操作技巧总结
  • Zend Framework数据库操作方法实例总结
  • Zend Framework入门教程之Zend_Db数据库操作详解
  • ZendFramework框架实现连接两个或多个数据库的方法
  • Zend Framework连接Mysql数据库实例分析
  • 解析如何使用Zend Framework 连接数据库
  • zend framework配置操作数据库实例分析
  • windows下zendframework项目环境搭建(通过命令行配置)
  • zend framework多模块多布局配置
  • Zend Framework开发入门经典教程
  • ZendFramework2连接数据库操作实例


  • 上一条:
    CI配置多数据库访问的方法
    下一条:
    Symfony2使用Doctrine进行数据库查询方法实例总结
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客