本文实例讲述了ZendFramework2连接数据库操作。分享给大家供大家参考,具体如下:

相对于zf1,来说,zf2让我们对于数据库这方面的操作我的个人感觉是对于字段起别名简单了,但是对数据库的操作虽然配置写好的就基本不需要动了,但是还是比1的配置要繁琐,
还是那句话,大家可以去看看源码。。。
Module.php 里面添加
public function getServiceConfig()
{
return array(
'factories' => array(
'Student\Model\StudentTable' => function($sm) {
$tableGateway = $sm->get('StudentTableGateway');
$table = new StudentTable($tableGateway);
return $table;
},
'StudentTableGateway' => function ($sm) {
$dbAdapter = $sm->get('Zend\Db\Adapter\Adapter');
$resultSetPrototype = new ResultSet();
$resultSetPrototype->setArrayObjectPrototype(new Student());
return new TableGateway('cc_user', $dbAdapter, null, $resultSetPrototype);//table Name is cc_user
},
),
);
}
student.php 这个是Model/Student.php
namespace Student\Model;
class Student
{
public $id;
public $name;
public $phone;
public $mark;
public $email;
public function exchangeArray($data)//别名
{
$this->id = (!empty($data['cc_u_id'])) ? $data['cc_u_id'] : null;
$this->name = (!empty($data['cc_u_name'])) ? $data['cc_u_name'] : null;
$this->phone = (!empty($data['cc_u_phone'])) ? $data['cc_u_phone'] : null;
$this->mark = (!empty($data['cc_u_mark'])) ? $data['cc_u_mark'] : null;
$this->email = (!empty($data['cc_u_email'])) ? $data['cc_u_email'] : null;
}
}
StudentTable.php Model/StudentTable.php
<?php
namespace Student\Model;
use Zend\Db\ResultSet\ResultSet;
use Zend\Db\TableGateway\TableGateway;
use Zend\Db\Sql\Select;
use Zend\Paginator\Adapter\DbSelect;
use Zend\Paginator\Paginator;
class StudentTable
{
protected $tableGateway;
protected $table='cc_user';
public function __construct(TableGateway $tableGateway)
{
$this->tableGateway = $tableGateway;
}
public function fetchAll($paginated)
{//分页
if($paginated) {
// create a new Select object for the table album
$select = new Select('cc_user');
// create a new result set based on the Student entity
$resultSetPrototype = new ResultSet();
$resultSetPrototype->setArrayObjectPrototype(new Student());
// create a new pagination adapter object
$paginatorAdapter = new DbSelect(
// our configured select object
$select,
// the adapter to run it against
$this->tableGateway->getAdapter(),
// the result set to hydrate
$resultSetPrototype
);
$paginator = new Paginator($paginatorAdapter);
return $paginator;
}
$resultSet = $this->tableGateway->select();
return $resultSet;
}
public function getStudent($id)
{
$id = (int) $id;
$rowset = $this->tableGateway->select(array('id' => $id));
$row = $rowset->current();
if (!$row) {
throw new \Exception("Could not find row $id");
}
return $row;
}
public function deleteStudent($id)
{
$this->tableGateway->delete(array('id' => $id));
}
public function getLIValue(){
return $this->tableGateway->getLastInsertValue();
}
}
Student/IndexController.php 调用数据库
public function indexAction(){
/* return new ViewModel(array(
'students' => $this->getStudentTable()->fetchAll(), //不分页
));*/
$page=$this->params('page');//走分页 在model.config.php里面设置:
/* model.config.php
'defaults' => array(
'controller' => 'Student\Controller\Index',
'action' => 'index',
'page'=>'1',
),
*/
$paginator = $this->getStudentTable()->fetchAll(true);
// set the current page to what has been passed in query string, or to 1 if none set
$paginator->setCurrentPageNumber((int)$this->params()->fromQuery('page', $page));
// set the number of items per page to 10
$paginator->setItemCountPerPage(10);
return new ViewModel(array(
'paginator' => $paginator //模板页面调用的时候的名字
));
//print_r($this->getStudentTable()->fetchAll());
}
在模板页面的调用
<?php foreach ($this->paginator as $student) : ?>
<tr id="<?php echo $this->escapeHtml($student->id);?>">
<td><?php echo $this->escapeHtml($student->id);?></td>
<td><?php echo $this->escapeHtml($student->name);?></td>
<td><?php echo $this->escapeHtml($student->phone);?></td>
<td><?php echo $this->escapeHtml($student->email);?></td>//应用了在Student.php的别名
<td><?php echo $this->escapeHtml($student->mark);?></td>
<td><a href='#' class='icol-bandaid editUserInfo'></a>
<a href='#' class='icol-key changePwd'></a>
<a herf='#' class='icol-cross deleteStud'></a>
</td>
</tr>
<?php endforeach;?>
更多关于zend相关内容感兴趣的读者可查看本站专题:《Zend FrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Zend Framework框架的PHP程序设计有所帮助。
# ZendFramework2
# 连接
# 数据库
# 解决了Ajax、MySQL 和 Zend Framework 的乱码问题
# Zend Framework数据库操作技巧总结
# Zend Framework入门应用实例详解
# Zend Framework前端控制器用法示例
# Zend Framework路由器用法实例详解
# Zend Framework分发器用法示例
# Zend Framework动作控制器用法示例
# Zend Framework处理Json数据方法详解
# Zend Framework使用Zend_Loader组件动态加载文件和类用法详解
# Zend Framework实现自定义过滤器的方法
# WINDOWS + WAMP + Zend Framework 配置步骤分享
# Zend Framework框架中实现Ajax的方法示例
# 分页
# 程序设计
# 相关内容
# 让我们
# 不需要
# 感兴趣
# 用了
# 给大家
# 动了
# 相对于
# 更多关于
# 所述
# 写好
# 面向对象
# 操作技巧
# 连接数据库
# 讲述了
# 那句话
# cc_u_id
# null
相关文章:
开封网站制作公司,网络用语开封是什么意思?
广州建站公司哪家好?十大优质服务商推荐
建站之星如何实现五合一智能建站与营销推广?
官网网站制作腾讯审核要多久,联想路由器newifi官网
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
香港服务器部署网站为何提示未备案?
建设网站制作价格,怎样建立自己的公司网站?
如何快速搭建支持数据库操作的智能建站平台?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
如何在Golang中处理模块冲突_解决依赖版本不兼容问题
香港服务器租用费用高吗?如何避免常见误区?
如何通过FTP服务器快速搭建网站?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
建站之星如何修改网站生成路径?
如何快速生成凡客建站的专业级图册?
如何在IIS7上新建站点并设置安全权限?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
C#怎么使用委托和事件 C# delegate与event编程方法
建站之星备案是否影响网站上线时间?
建站主机与虚拟主机有何区别?如何选择最优方案?
网站制作企业,网站的banner和导航栏是指什么?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
C#怎么创建控制台应用 C# Console App项目创建方法
设计网站制作公司有哪些,制作网页教程?
如何在云主机上快速搭建多站点网站?
在线教育网站制作平台,山西立德教育官网?
建站之星下载版如何获取与安装?
高端网站建设与定制开发一站式解决方案 中企动力
如何使用Golang table-driven基准测试_多组数据测量函数效率
开心动漫网站制作软件下载,十分开心动画为何停播?
成都网站制作报价公司,成都工业用气开户费用?
,网站推广常用方法?
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
如何用花生壳三步快速搭建专属网站?
建站主机CVM配置优化、SEO策略与性能提升指南
南平网站制作公司,2025年南平市事业单位报名时间?
如何选择适配移动端的WAP自助建站平台?
Java解压缩zip - 解压缩多个文件或文件夹实例
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
家具网站制作软件,家具厂怎么跑业务?
如何确认建站备案号应放置的具体位置?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
如何快速搭建二级域名独立网站?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
黑客如何利用漏洞与弱口令入侵网站服务器?
如何打造高效商业网站?建站目的决定转化率
javascript中对象的定义、使用以及对象和原型链操作小结
如何在IIS7中新建站点?详细步骤解析
*请认真填写需求信息,我们会在24小时内与您取得联系。