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

时间:2022-08-24 13:42:39

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

我们先要在数据库里建立一个叫message的表,它有三个字段.分别为id,title,content.其中id为主键.

现在我们开始第一步:在application文件夹下面加入一个config文件夹,并在这里面增加一个config.ini文件..这里面是配置数据库基本信息.

如下代码所示:

?
1
2
3
4
5
6
[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文件..这里命名是以数据表名称相同.

?
1
2
3
4
5
<?php
class Message extends Zend_Db_Table {
protected $_name ="message";
protected $_primary = 'id';
}

第三步:接下来..我们要在我们的入口文件index.php里加入下面代码如下:

?
1
2
3
4
5
6
7
8
//配置数据库参数,并连接数据库
$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控制器进行操作了..分别有四个方法.它们的作用就是增加数据,修改,

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
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 Framework框架的PHP程序设计有所帮助。