PHP操作数据分页

一、数据库安全

string addslashes ( string $str )
返回字符串,该字符串为了数据库查询语句等的需要在某些字符前加上了反斜线。这些字符是单引号(')、双引号(")、反斜线(\)与 NUL(NULL 字符)。 一个使用 addslashes() 的例子是当你要往数据库中输入数据时。例如,将名字 O'reilly 插入到数据库中,这就需要对其进行转义。大多数据库使用 \ 作为转义符:O\'reilly。这样可以将数据放入数据库中,而不会插入额外的 \。当 PHP 指令 magic_quotes_sybase 被设置成 on 时,意味着插入 ' 时将使用 ' 进行转义。 默认情况下,PHP 指令 magic_quotes_gpc 为 on,它主要是对所有的 GET、POST 和 COOKIE 数据自动运行 addslashes()。不要对已经被 magic_quotes_gpc 转义过的字符串使用 addslashes(),因为这样会导致双层转义。遇到这种情况时可以使用函数 get_magic_quotes_gpc() 进行检测。

二、分页

首先说一下分页的核心思想:首先当前页,页面大小,总记录数。这个三个数值可以通过总记录数和页面大小,我们就可以计算出总的页数。

# 1、连接MySQL服务器
$link = @mysqli_connect('localhost','root','123456','school'); if(!$link){
$logs = date('Y-m-d H:i:s');
$logs .= ' mysql错误编码:'.mysqli_connect_errno().'错误信息:'.mysqli_connect_error();
file_put_contents('mysql_error.log',$logs . PHP_EOL,FILE_APPEND);
exit('亲 MySQL连接失败!');
} # 2、设置字符集
if( !mysqli_set_charset($link,'utf8') ){
$logs = date('Y-m-d H:i:s');
$logs .= ' mysql错误编码:'.mysqli_errno($link).'错误信息:'.mysqli_error($link);
file_put_contents('mysql_error.log',$logs . PHP_EOL,FILE_APPEND);
}

1、总记录数

// 获取总的记录数
$sql_total_records = "select count(*) from innodb_table_stats";
$total_records_result = mysqli_query($link,$sql_total_records);
$total_records = mysqli_fetch_row($total_records_result);
echo "总的记录数位: ".$total_records[0]."<br>";

2、当前页

# 通过GET方式获取客户端访问的页码
$current_page = isset($_GET['page_number']) ?$_GET['page_number'] : 1; if( $current_page < 1 ){
$current_page = 1;
}
if( $current_page > $total_pages ){
$current_page = $total_pages
}

3、分页核心

$begin_position = ($current_page_number-1) * $page_size;
$sql = "select * from tb_user limit $begin_position,$page_size";
$result = mysqli_query($link,$sql);

4、页面展示

echo '<a href="index.php?page_number=1">首页</a>&nbsp;&nbsp;';
for($i=1;$i<=$total_pages;$i++){
echo '<a href="./index.php?page_number='.$i.'">第'.$i.'页</a>&nbsp;&nbsp;';
}
echo '<a href="index.php?page_number='.($current_page_number-1).'">上一页</a>&nbsp;&nbsp;';
echo '<a href="index.php?page_number='.($current_page_number+1).'">下一页</a>&nbsp;&nbsp;';
echo '<a href="index.php?page_number='.($total_pages).'">尾页</a>&nbsp;&nbsp;';

贡献代码

header('content-type:text/html;charset=utf-8');

# 1、连接MySQL服务器
$link = @mysqli_connect('localhost','root','123456','school'); if(!$link){
$logs = date('Y-m-d H:i:s');
$logs .= ' mysql错误编码:'.mysqli_connect_errno().'错误信息:'.mysqli_connect_error();
file_put_contents('mysql_error.log',$logs . PHP_EOL,FILE_APPEND);
exit('亲 MySQL连接失败!');
} # 2、设置字符集
if( !mysqli_set_charset($link,'utf8') ){
$logs = date('Y-m-d H:i:s');
$logs .= ' mysql错误编码:'.mysqli_errno($link).'错误信息:'.mysqli_error($link);
file_put_contents('mysql_error.log',$logs . PHP_EOL,FILE_APPEND);
}
//--------------------------------------------------------------------------
# 获取总记录数
$t_sql = "select count(*) as t from student";
$res = mysqli_query($link,$t_sql);
$row = mysqli_fetch_assoc($res);
$total = $row['t']; # 每页显示多少记录
$pageRows = 2; # 获取总页数
$tPage = ceil($total/$pageRows); # 根据当前页码 来生成查询用的SQL
if(isset($_GET['p']) && intval($_GET['p'])){
$page = $_GET['p'] > $tPage ? $tPage : $_GET['p'];
}else{
$page = 1;
} $start = ($page-1)*$pageRows;
$sql = "select * from student limit $start,$pageRows"; //------------------------------------------------------------------ # 4、执行SQL $result 查询出来的结果集
$result = mysqli_query($link,$sql); echo '<table border="1" width="600" align="center">';
while($rows = mysqli_fetch_assoc($result)){
echo '<tr>
<td>'.$rows['sno'].'</td>
<td>'.$rows['sname'].'</td>
<td>'.$rows['ssex'].'</td>
<td>'.$rows['sbirthday'].'</td>
<td>'.$rows['class'].'</td>
</tr>';
}
echo '</table>'; # 5、收功
mysqli_free_result($result); # 6、关闭数据库连接
mysqli_close($link); ?>
<style>
a {
border:1px solid red;
padding:2px;
margin-right:3px;
text-decoration:none;
}
</style>
<div style="width:500px;margin:20px auto;">
<?php
echo "<a href='page.php?p=1'>首页</a>";
echo "<a href='page.php?p=".($page-1)."'>上一页</a>";
for($i=1;$i<=$tPage;$i++){
echo "<a href='page.php?p=$i'>$i</a>";
}
echo "<a href='page.php?p=".($page+1)."'>下一页</a>";
echo "<a href='page.php?p=$tPage'>尾页</a>";
?>
</div>

PHP操作数据分页的更多相关文章

  1. 腾讯云图片鉴黄集成到C# SQL Server 怎么在分页获取数据的同时获取到总记录数 sqlserver 操作数据表语句模板 .NET MVC后台发送post请求 百度api查询多个地址的经纬度的问题 try{}里有一个 return 语句,那么紧跟在这个 try 后的 finally {}里的 code 会 不会被执行,什么时候被执行,在 return 前还是后? js获取某个日期

    腾讯云图片鉴黄集成到C#   官方文档:https://cloud.tencent.com/document/product/641/12422 请求官方API及签名的生成代码如下: public c ...

  2. jQuery异步分页插件

    学校软件工程让写课程设计(其实就是自选语言做个项目),感觉都是重复的东西就没有很认真的去写内容,更加注意写一些之前没有用过的东西. 因为一直都使用TP框架来写PHP,TP又自带分页类,想到这里就想试试 ...

  3. Python Django的分页,Form验证,中间件

    本节内容 Django的分页 Form 中间件 1 Django 分页 1.1 Django自带的分页 1.首先来看下我的测试数据环境 ############ models.py ######### ...

  4. el-table复选框分页记忆

    el-table 结合 el-pagination 实现分页后默认是没有复选框记忆功能的,对于这样的需求,无奈又只能硬着头皮上,试了网上的一些方法,没奏效,便自己上了. 简单的用法如下: <te ...

  5. Solr中使用游标进行深度分页查询以提高效率(适用的场景下)

    通常,我们的应用系统,如果要做一次全量数据的读取,大多数时候,采用的方式会是使用分页读取的方式,然而 分页读取的方式,在大数据量的情况下,在solr里面表现并不是特别好,因为它随时可能会发生OOM的异 ...

  6. YII2中分页组件的使用

    当数据过多,无法一页显示时,我们经常会用到分页组件,YII2中已经帮我们封装好了分页组件. 首先我们创建操作数据表的AR模型: <?php namespace app\models; use y ...

  7. EF批量操作数据与缓存扩展框架

    前言 在原生的EF框架中,针对批量数据操作的接口有限,EF扩展框架弥补了EF在批量操作时的接口,这些批量操作包括:批量修改.批量查询.批量删除和数据缓存,如果您想在EF中更方便的批量操作数据,这个扩展 ...

  8. 数据库分库分表和带来的唯一ID、分页查询问题的解决

    需求缘起(用一个公司的发展作为背景) 1.还是个小公司的时候,注册用户就20w,每天活跃用户1w,每天最大单表数据量就1000,然后高峰期每秒并发请求最多就10,此时一个16核32G的服务器,每秒请求 ...

  9. 【MyBatis】MyBatis分页插件PageHelper的使用

    好多天没写博客了,因为最近在实习,大部分时间在熟悉实习相关的东西,也没有怎么学习新的东西,这周末学习了MyBatis的一个分页插件PageHelper,虽然没有那么的强大(我在最后会说明它的缺点),但 ...

  10. AngularJS入门 & 分页 & CRUD示例

    一.AngularJS 简介 ​ AngularJS  诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀的前端JS框架,已经被用于Google的多款产品当中. ...

随机推荐

  1. 15-触摸按键控制LED灯

    1.触摸按键 触摸按键可分为四大类:电阻式,电容式,红外感应式和表面声波式 电阻式触摸按键使用人体破压电阻,改变电阻,实现开关效果,耐用性差,很少使用 红外感应式是通过红外扫描的方式,一般使用在比较恶 ...

  2. JS - 递归实现无限分类

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. Shell-函数-function

  4. mysq-DQL-过滤条件-where

  5. Go-数组-实现队列

    package main import ( "errors" "fmt" ) // 队列 // 特征: // 1. 按照元素的添加顺序排序,并且容量固定 // ...

  6. 【面试题精讲】Redis如何实现分布式锁

    首发博客地址 系列文章地址 Redis 可以使用分布式锁来实现多个进程或多个线程之间的并发控制,以确保在给定时间内只有一个进程或线程可以访问临界资源.以下是一种使用 Redis 实现分布式锁的常见方法 ...

  7. [转帖]日常Bug排查-读从库没有原子性?

    https://zhuanlan.zhihu.com/p/658508920 3 人赞同了该文章 日常Bug排查系列都是一些简单Bug排查.问题虽小,但经常遇到,了解这些问题,会让我们少走点弯路,提升 ...

  8. [转帖]global cache cr request等待事件分析及优化

    在RAC环境中,和全局调整缓存相关的最常见的等待事件无非就是:global cache cr request,global cache busy和equeue 在XX电信做了一次数据库巡检中发现,sp ...

  9. [转帖]kafka搭建kraft集群模式

    kafka2.8之后不适用zookeeper进行leader选举,使用自己的controller进行选举 1.准备工作 准备三台服务器 192.168.3.110 192.168.3.111 192. ...

  10. 【转帖】Linux性能优化(十六)——中断绑定

    一.中断绑定简介 1.中断简介 计算机中,中断是一种电信号,由硬件产生并直接送到中断控制器上,再由中断控制器向CPU发送中断信号,CPU检测到信号后,中断当前工作转而处理中断信号.CPU会通知操作系统 ...