PHP分页

Jun 21, 2016 am 08:48 AM
index php

今天在工作之余写的一段PHP分页处理脚本,欢迎拍砖!!! 显示页面 index.php

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<?php

        require_once 'include/showbbsProcess.php';

        require_once 'include/showbbs_fun.php';    

        @$connectmysql=new connectMysql();

         

        if (empty($_GET['CurrentPageID'])){

            $CurrentPageID=1;//当前是第几页

        }else {

            $CurrentPageID=$_GET['CurrentPageID'];

        }

         

        $PageSize=5;

        echo showCenter($CurrentPageID, $PageSize, $connectmysql);

        ?>

登入後複製

分页处理函数 showbbsProcess.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

<?php

function showCenter($CurrentPageID,$PageSize=5,$connectmysql){

    $arr=showbbs($PageSize, $CurrentPageID, $connectmysql);

    foreach ($arr as $values){

        for ($i=0;$i<count($arr);$i++){

            echo ''.$arr[$i]['title'].''.' '.'<span style="float:right;font-size:12px;">作者:'.$arr[$i]['poster'].' '.'发布时间:'.$arr[$i]['posted'].'</span><br/><hr />';

            //如果遍历完$arr数组里的所以元素,即$i($i从0开始)等于数组的元素个数减一,则跳出2层循环(for循环和foreach循环)

            if ($i==(count($arr)-1))

                break 2;

        }

    }

     

    $RowCount=getRowCount($connectmysql);//一共有多少条记录

     

    $PageCount=ceil($RowCount/$PageSize);//共有几页,ceil()函数进一取整

     

    echo '帖子统计:'.$RowCount.'条'.' '.'共有'.$PageCount.'页 ';

     

    //当为第一页时不输出“上一页”

    if ($CurrentPageID != 1){

        echo "上一页";

    }

     

    //向前跳页

    if ($CurrentPageID > 2){

        echo " <<< ";

    }

     

    //输出详细的页数,如:【1】

    for ($j=1;$j<=$PageCount;$j++){

        echo "[$j]";

    }

     

    //向后跳页

    if ($CurrentPageID <= ($PageCount-2)){

        echo " >>> ";

    }

     

    //当为最后一页时不输出“下一页”

    if ($CurrentPageID != $PageCount){

        echo "下一页";

    }

     

    $connectmysql->closeConn();

}

登入後複製

与数据库沟通的函数 showbbs_fun.php

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<?php

require_once '/class/connectMysql.php';

 

//该函数用来获取数据库中的数据并返回一个二维数组

function showbbs($PageSize,$CurrentPageID,$connectmysql){

    $a=($CurrentPageID - 1)*$PageSize;

    $sql="select * from db_content limit $a,$PageSize";

    $arr1=$connectmysql->getRowsArray($sql);

    return $arr1;

}

 

//该函数用来查询数据库的表的行数

function getRowCount($connectmysql){

    $sql="select * from db_content";

    $num=$connectmysql->getRowsNum($sql);

    return $num;

}

登入後複製

数据库类 connectMysql.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

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

<?php

/***

 * 这个类用于处理数据库连接相关操作

 */

class connectMysql{

    private $host='localhost';

    private $username='root';

    private $password='szy19900316';

    private $dbname='db_caomei';

    private $conn='';//数据库连接资源

    private $result='';//查询的结果

    private $resultArray;//将查询的结果输出为一个单条记录的数组

    private $rowsArray=array();//含有多条记录的二维数组

    private $rowsNum=0;//返回的结果数

     

    function __construct(){

    }

     

    //连接数据库

    function conndb(){

        $this->conn=mysql_connect($this->host,$this->username,$this->password);

        @mysql_select_db($this->dbname,$this->conn);

        mysql_query('set names utf-8');

    }

     

    //查询结果

    function getResult($sql){

        if ($this->conn==''){

            $this->conndb();

        }

        $this->result=mysql_query($sql,$this->conn);

    }

     

    //返回查询的记录数

    function getRowsNum($sql){

        $this->getResult($sql);

        $num_rows=mysql_num_rows($this->result);

        if (mysql_errno()==0){

            return $num_rows;

        }else {

            return '';

        }

    }

     

    //将结果输出为一个单条记录数组并返回

    function getArray($sql){

        $this->getResult($sql);

        if (mysql_errno()==0){

            $this->resultArray=mysql_fetch_array($this->result,MYSQL_ASSOC);//得到关联数组

            return $this->resultArray;

        }else {

            return '';

        }

    }

     

    //返回一个含有多条记录的二维数组

    function getRowsArray($sql){

        $this->getResult($sql);

        if (mysql_errno()==0){

            while ($row=mysql_fetch_array($this->result,MYSQL_ASSOC)){

                $this->rowsArray[]=$row;

            }

            return $this->rowsArray;

            //print_r($this->rowsArray);exit;

        }else {

            return '';

        }

    }

 

    //更新、添加、删除

    function uidresult($sql){

        if ($this->conn==''){

            $this->conndb();

        }

        //echo $sql;

        //exit;

        @mysql_query($sql);

        $this->rowsNum=@mysql_affected_rows();

        if (mysql_errno()==0){

            return $this->rowsNum;

        }else {

            return '';

        }

    }

     

    //释放结果集

    function freeResult(){

        mysql_free_result($this->result);

        $this->rowsNum=0;

        $this->rowsArray='';

        $this->resultArray='';

    }

     

    //关闭数据库

    function closeConn(){

        $this->freeResult();

        mysql_close($this->conn);

        $this->conn='';

    }

}

登入後複製



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

CakePHP 專案配置 CakePHP 專案配置 Sep 10, 2024 pm 05:25 PM

在本章中,我們將了解CakePHP中的環境變數、常規配置、資料庫配置和電子郵件配置。

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

CakePHP 日期和時間 CakePHP 日期和時間 Sep 10, 2024 pm 05:27 PM

為了在 cakephp4 中處理日期和時間,我們將使用可用的 FrozenTime 類別。

CakePHP 檔案上傳 CakePHP 檔案上傳 Sep 10, 2024 pm 05:27 PM

為了進行文件上傳,我們將使用表單助理。這是文件上傳的範例。

CakePHP 路由 CakePHP 路由 Sep 10, 2024 pm 05:25 PM

在本章中,我們將學習以下與路由相關的主題?

討論 CakePHP 討論 CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP 是 PHP 的開源框架。它旨在使應用程式的開發、部署和維護變得更加容易。 CakePHP 基於類似 MVC 的架構,功能強大且易於掌握。模型、視圖和控制器 gu

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

CakePHP 建立驗證器 CakePHP 建立驗證器 Sep 10, 2024 pm 05:26 PM

可以透過在控制器中新增以下兩行來建立驗證器。

See all articles