美文网首页程序员
PDO分页查询模块介绍

PDO分页查询模块介绍

作者: Vett | 来源:发表于2017-08-23 21:49 被阅读0次

简介

源码请移步GitHub

schu-database是SchuEngine中的数据库模块,可以独立使用,也可以利用zend-servicemanager驱动.

与上个版本的schu-database不同,这个版本完全脱离zend-db,依托于使用最广泛的PDO扩展,实现与数据库的交互.

之所以弃用zend-db作为底层,是因为其高昂的学习成本,直接导致了schu-database更加高昂的学习成本,需要不停的查阅手册,这不利于SchuEngine最初的期望.

在用法上schu-database完全等同于PDO的原生操作,最大程度上降低了学习成本.

在分页上,schu-database会通过传入的SQL语句.在原有SQL的基础上,自动生成分页查询,并且调用极其简单.

依赖

PDO扩展

安装

$ composer require schuengine/schu-database

配置

一般情况下(完全等同于PDO的__construct):

<?php

use Schu\Database\Database;

/**
 * data source name of PDO $dsn
 * db username $user
 * db password $password
 * options array $options
 */
$db = new Database($dsn, $user, $password, $options);

传入数组:

<?php

use Schu\Database\Database;

$dbOptions = [
    'dsn' => 'mysql:host=localhost;dbname=test',
    'username' => 'username',
    'password' => '********',
    'options' => [
        //PDO options
    ],
];

$db = new Database($dbOptions);

通过zend-servicemanager

//在 ./config/autoload/global.php中
'schu-database' => [
    'dsn' => 'mysql:host=localhost;dbname=test',
    'options' => [
        //PDO options
    ],
],

//在./config/autoload/local.php中
'schu-database' => [
    'username' => 'username',
    'password' => '********',
],

//在应用中
$db = $container->get('schu-database');

使用

在使用过程中,schu-database的操作完全继承了PDO,比PDO多一个接口,即分页.后续介绍.

所以,你可以直接将Schu\Database\Database即上例中的$db当做PDO来操作.

分页

schu-database的分页接口非常简单如下:

/**
 * Get paginator result 
 * 
 * @param  integer $page 
 * @param  integer $itemCountPerPage 
 * @param  string $sql 
 * @throws \Schu\Database\Exception\InvalidArgumentException 
 * @throws \Schu\Database\Exception\RuntimeException
 * @return Page 
 */ 
 public function getPaginatorResult($page, $itemCountPerPage, $sql);

调用后,schu-database会自动解析传入的SQL语句.

  1. 获得原始的ORDER BY,LIMIT,OFFSET以及子查询语句.
  2. 生成原SQL语句的COUNT语句.
  3. 比对LIMITCOUNT结果,输出正确的结果集总数.
  4. 生成分页查询语句.
  5. 实例化\Schu\Database\Page,并返回.

类\Schu\Database\Page中包含分页结果集的全部数据,包括:

  1. 当前页
  2. 总页数
  3. 每页条目数
  4. 总条目数
  5. 结果集数组
  6. 原查询语句
  7. 分页查询语句
  8. COUNT语句

详细API请移步PageInterface

相关文章

  • PDO分页查询模块介绍

    简介 源码请移步GitHub schu-database是SchuEngine中的数据库模块,可以独立使用,也可以...

  • MongoDB分页查询 --- 2022-04-03

    本章介绍,MongoDB的分页查询,类似MYSQL分页的用法,MongoDB的分页查询通过Cursor游标的.li...

  • MyBatis 学习笔记(9) 分页查询

    1. 背景 在 mybatis 中经常用到分页查询,本文介绍下使用 PageHelper 进行分页查询。 2.知识...

  • 十六. springboot整合分页插件PageHelper

    一. 概述 后端开发80%都是查询操作, 而查询经常涉及到数据分页, 分页工具有很多, 本文介绍的是分页插件Pag...

  • PDO:预处理语句(参数化查询)

    @(PDO(PHP data object/PHP数据对象))[PDO|预处理语句|参数化查询] PDO Tuto...

  • mybatis

    介绍 mybatis 加载配置文件 增删改查/分页查询 别名配置 定义结果集 动态SQL(增删改查/分页查询) 关...

  • SQL基础(一)

    问 介绍下数据库分页原理: 使用LIMIT子句实现分页查询 在所有的查询结果中,返回前5行记录。SELECT ...

  • ASP.NET MVC5 实现分页查询

    对于大量数据的查询和展示使用分页是一种不错的选择,这篇文章简要介绍下自己实现分页查询的思路。 分页需要三个变量:数...

  • MongoDB查询结果排序 --- 2022-04-03

    本章介绍,MongoDB查询结果排序,类似MYSQL order by的用法,MongoDB的分页查询通过Curs...

  • hibernate中的查询

    HQL 查询所有 条件查询 分页查询 Criteria 查询所有 条件查询 分页查询 查询总记录 原生SQL

网友评论

    本文标题:PDO分页查询模块介绍

    本文链接:https://www.haomeiwen.com/subject/ltwjdxtx.html