zendframework2数据库网关及分页简化
鉴于zendframework2在国内的教程比较少,本人有感而发,写下此篇关于zf2框架的技术文章,希望能帮助到需要的人。
一、config\autoload\global.php
<?php //php中文网 www.php.cn return array( 'db' => array( 'driver' => 'pdo', 'driver_options' => array( \PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES \'UTF8\'' ) ) );
二、config\autoload\local.php
<?php //php中文网 www.php.cn return array( 'db' => array( 'dsn' => 'mysql:dbname=testdb;hostname=localhost', 'username' => 'root', 'password' => 'root', 'prefix' => 'phpcn_' ), );
三、module\Application\Module.php
public function getServiceConfig() { return array( 'factories'=>array( 'Application\Model\Db'=>function($sm){ $service=new Model\Db($sm); return $service; }, 'Db\Adapter'=>function($sm){ $configs=$sm->get('Config'); $adapter = new \Zend\Db\Adapter\Adapter($configs['db']); return $adapter; }, 'Db\Feature'=>function($sm){ $configs=$sm->get('Config'); $Feature=new \Application\Model\TableNamePrefixFeature($configs['db']['prefix']); return $Feature; }, 'Db\Padapter'=>function($sm){ $Padapter=new \Zend\Paginator\Adapter\DbSelect($sm->get('Application\Model\Db')->select,$sm->get('Db\Adapter')); return $Padapter; }, 'Db\Paginator'=>function($sm){ $Paginator=new \Zend\Paginator\Paginator($sm->get('Db\Padapter')); return $Paginator; }, ), 'abstract_factories'=>array('Application\Services\CommonDbAbstractFactory') ); }
四、module\Application\view\pagination\tmpl.phtml
<?php if ($this->pageCount): ?> <p class="pageX"> <?php if (isset($this->previous)): ?> <a href="<?php echo $this->url().'?p='.$this->previous;?>">< 前一页</a> | <?php else: ?> <span>< 前一页</span> | <?php endif; ?> <?php foreach ($this->pagesInRange as $page): ?> <?php if ($page != $this->current): ?> <a href="<?php echo $this->url().'?p='.$page;?>"><?php echo $page;?></a> | <?php else: ?> <?php echo $page; ?> | <?php endif; ?> <?php endforeach; ?> <?php if (isset($this->next)): ?> <a href="<?php echo $this->url().'?p='.$this->next;?>">下一页 ></a> <?php else: ?> <span>下一页 ></span> <?php endif; ?> </p> <?php endif; ?>
五、module\Application\src\Application\Services\CommonDbAbstractFactory.php
<?php //php中文网 www.php.cn namespace Application\Services; use Zend\ServiceManager\AbstractFactoryInterface; use Zend\ServiceManager\ServiceLocatorInterface; class CommonDbAbstractFactory implements AbstractFactoryInterface { public function canCreateServiceWithName(ServiceLocatorInterface $locator, $name, $requestedName) { $a=explode(':',$name); if(!empty($a[0]) && $a[0]=='db'){ return true; } return false; } public function createServiceWithName(ServiceLocatorInterface $locator, $name, $requestedName) { $a=explode(':',$name); return $locator->get('Application\Model\Db')->get($a[1]); } }
六、module\Application\src\Application\Model\Db.php
<?php //php中文网 www.php.cn namespace Application\Model; use Zend\Db\TableGateway\TableGateway; use Zend\ServiceManager\ServiceManager; class Db { public function construct(ServiceManager $sm){ $this->sm=$sm; } public function get($tablename=null) { $configs=$this->sm->get('Config'); $adapter=$this->sm->get('Db\Adapter'); $dbFeature=$this->sm->get('Db\Feature'); $this->db=new TableGateway($tablename,$adapter,$dbFeature); $this->select=$this->db->getSql()->select(); return $this; } public function fetch(){ return $this->db->selectWith($this->select); } public function getSql(){ return $this->select; } public function getTableGateway(){ return $this->db; } public function select($where = null){ return $this->db->select($where); } public function insert($set){ return $this->db->insert($set); } public function update($set, $where = null){ return $this->db->update($set,$where); } public function delete($where){ return $this->db->delete($where); } public function call($functionName,$args){ $this->select=call_user_func_array(array($this->select,$functionName),$args); return $this; } }
七、module\Application\src\Application\Model\TableNamePrefixFeature.php
<?php //php中文网 www.php.cn namespace Application\Model; use Zend\Db\TableGateway\Feature\AbstractFeature; class TableNamePrefixFeature extends AbstractFeature { protected $prefix=null; public function construct($prefix=null) { if(null!==$prefix) { $this->setPrefix($prefix); } } public function setPrefix($prefix) { $this->prefix=$prefix; } public function postInitialize() { if(null!==$this->prefix){ $this->tableGateway->getSql()->setTable($this->prefix.$this->tableGateway->table); } } }
八、module\Application\src\Application\Controller\IndexController.php
$this->sm=$this->getServiceLocator(); $this->model=$this->sm->get('db:model'); $p=intval($this->getRequest()->getQuery('p',1)); $per_page=1; $result=$this->model->where('id > 2')->order('id DESC')->limit($per_page)->offset(($p-1)*$per_page)->fetch()->toArray(); $paginator=$this->sm->get('Db\Paginator'); $paginator->setCurrentPageNumber($p); $paginator->setItemCountPerPage($per_page); \Zend\Debug\Debug::dump($result); echo $this->sm->get('ViewRenderer')->paginationcontrol($paginator, 'Sliding', 'pagination/tmpl.phtml');
【本文由“Ty80账号”发布,2017年7月13日】
以上是zendframework2数据库网关及分页简化的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Go语言是一种高效、简洁且易于学习的编程语言,因其在并发编程和网络编程方面的优势而备受开发者青睐。在实际开发中,数据库操作是不可或缺的一部分,本文将介绍如何使用Go语言实现数据库的增删改查操作。在Go语言中,我们通常使用第三方库来操作数据库,比如常用的sql包、gorm等。这里以sql包为例介绍如何实现数据库的增删改查操作。假设我们使用的是MySQL数据库。

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

HTML无法直接读取数据库,但可以通过JavaScript和AJAX实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用JavaScript、AJAX和PHP来从MySQL数据库读取数据的实战示例,展示了如何在HTML页面中动态显示查询结果。该示例使用XMLHttpRequest建立数据库连接,发送查询并处理响应,从而将数据填充到页面元素中,实现了HTML读取数据库的功能。

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

PHP是一种广泛应用于网站开发的后端编程语言,它具有强大的数据库操作功能,常用于与MySQL等数据库进行交互。然而,由于中文字符编码的复杂性,在处理数据库中文乱码时常常会出现问题。本文将介绍PHP处理数据库中文乱码的技巧与实践,包括常见的乱码原因、解决方法和具体的代码示例。常见的乱码原因数据库字符集设置不正确:数据库在创建时需选择正确的字符集,如utf8或u

通过Go标准库database/sql包,可以连接到MySQL、PostgreSQL或SQLite等远程数据库:创建包含数据库连接信息的连接字符串。使用sql.Open()函数打开数据库连接。执行SQL查询和插入操作等数据库操作。使用defer关闭数据库连接以释放资源。
