php 一个分页类和一个数据库的类

最近被迫写php,被搞的很郁闷,函数的返回值也不指定,变量的随意性太强,造成调试比较麻烦,oo也不是很好,但是写起来其实比较灵活,上手也比较容易。以后写php也不错哦。

下面是分页类和一个数据库的类。

php 分页类

ContractedBlock.gif ExpandedBlockStart.gif Code
 1<?php
 2//检查文件是否已加载
 3if(!function_exists(pageft)){ 
 4//定义函数$totle为数据总量,$displaypg为每页显示数
 5function pageft($totle,$displaypg,$url=''){
 6
 7global $page,$firstcount,$pagenav,$_SERVER;
 8
 9$GLOBALS["displaypg"]=$displaypg;
10//用$_GET来接受页参数
11if (isset($_GET['page'])){
12$page=intval($_GET['page']);
13}else{
14$page=1;
15}
16//$_SERVER["REQUEST_URI"]访问此页面的URI(路径)
17if(!$url){ $url=$_SERVER["REQUEST_URI"];}
18//解析URI,获得数组形式传送给$parse_url
19$parse_url=parse_url($url);
20//$parse_url["query"],获得?后的变量
21$url_query=$parse_url["query"];
22
23if($url_query){
24$url_query=ereg_replace("(^|&)page=$page","",$url_query);
25
26
27$url=str_replace($parse_url["query"],$url_query,$url);
28
29//在URL后加page查询信息,但待赋值: 
30if($url_query$url.="&page"else $url.="page";
31}else {
32$url.="?page";
33}
34
35$lastpg=ceil($totle/$displaypg); //最下一页,也是总页数
36$page=min($lastpg,$page);
37$prepg=$page-1//上一页
38$nextpg=($page==$lastpg ? 0 : $page+1); //下一页
39$firstcount=($page-1)*$displaypg;
40
41//开始分页导航条代码:
42/*
43$pagenav="显示第 <B>;".($totle?($firstcount+1):0)."</B>;-<B>;".min($firstcount+$displaypg,$totle)."</B>; 条记录,共 $totle 条记录";*/
44//如果只有一页则跳出函数:
45if($lastpg<=1return false;
46
47if ($page==1$pagenav.="<font color=#999999>首页 | </font>"else $pagenav.="<a href='$url=1'>首页</a> | ";
48if($prepg$pagenav.="<a href='$url=$prepg'>上一页</a> | "else $pagenav.="<font color=#999999>上一页 | </font>";
49if($nextpg$pagenav.="<a href='$url=$nextpg'>下一页</a> | "else $pagenav.=" <font color=#999999>下一页 | </font>";
50if ($page==$lastpg$pagenav.="<font color=#999999>末页 | </font>" ; else $pagenav.="<a href='$url=$lastpg'>末页</a> | ";
51
52//下拉跳转列表,循环列出所有页码:
53$pagenav.="转到第<select name='topage' size='1' οnchange='window.location=\"$url=\"+this.value'>;\n";
54for($i=1;$i<=$lastpg;$i++){
55if($i==$page$pagenav.="<option value='$i' selected>$i</option>\n";
56else $pagenav.="<option value='$i'>$i</option>\n";
57}
58$pagenav.="</select>页  ($page/$lastpg 页)";
59}
60}
61?>

 

 

 

ContractedBlock.gif ExpandedBlockStart.gif Code
 1 <?php
 2 class db_Mysql
 3 {
 4  
 5  var $dbServer;
 6  var $dbDatabase
 7  var $dbbase;
 8  var $dbUser;
 9  var $dbPwd;
10  var $dbLink;
11  var $result;// 执行query命令的指针
12  var $num_rows;// 返回的条目数
13  var $insert_id;// 传回最后一次使用 INSERT 指令的 ID
14  var $affected_rows;// 传回query命令所影响的列数目
15
16function dbconnect()
17{
18   $this->dbLink=@mysql_connect($this->dbServer,$this->dbUser,$this->dbPwd);
19   if(!$this->dbLink) $this->dbhalt("不能连接数据库!");
20   if($this->dbbase==""$this->dbbase=$this->dbDatabase;
21   if(!@mysql_select_db($this->dbbase,$this->dbLink))
22   $this->dbhalt("数据库不可用!");
23   mysql_query("SET NAMES 'gbk'");
24
25
26function execute($sql)
27{
28   $this->result=mysql_query($sql);
29   return $this->result;
30}
31
32function fetch_array($result)
33{
34    return mysql_fetch_array($result);
35}
36
37function get_rows($sql)
38{
39    return mysql_num_rows(mysql_query($sql));
40}
41
42function num_rows($result)
43{
44    return mysql_num_rows($result);
45}
46
47function data_seek($result,$rowNumber)
48{
49    return mysql_data_seek($result,$rowNumber);
50}
51
52function dbhalt($errmsg)
53{
54   $msg="database is wrong!";
55   $msg=$errmsg;
56   echo"$msg";
57   die();
58}
59
60function delete($sql){
61   $result=$this->execute($sql,$dbbase);
62   $this->affected_rows=mysql_affected_rows($this->dbLink);
63   $this->free_result($result);
64   return $this->affected_rows;
65}
66
67function insert($sql){
68$result=$this->execute($sql,$dbbase);
69$this->insert_id=mysql_insert_id($this->dbLink);
70$this->free_result($result);
71 return $this->insert_id;
72}
73
74function update($sql)
75{
76   $result=$this->execute($sql,$dbbase);
77   $this->affected_rows=mysql_affected_rows($this->dbLink);
78   $this->free_result($result);
79    return $this->affected_rows;
80}
81
82function get_num($result)
83{
84   $num=@mysql_numrows($result);
85   return $num;
86}
87 //释放所有与结果标识符 result 所关联的内存
88function free_result($result)
89{
90   @mysql_free_result($result);
91}
92
93function dbclose()
94{
95   mysql_close($this->dbLink);
96}
97
98}// end class
99?>

 

测试过都是可以用滴,已经在第一个程序中使用了。

转载于:https://www.cnblogs.com/wingurumqi/archive/2008/12/09/1351132.html

//为了避免重复包含文件而造成错误,加了判断函数是否存在的条件: $page = $_GET[page]; if(!function_exists(pageft)){ //定义函数pageft(),三个参数的含义为: //$totle:信息总数; //$displaypg:每页显示信息数,这里设置为默认是20; //$url:分页导航中的链接,除了加入不同的查询信息“page”外的部分都与这个URL相同。 //   默认值本该设为本页URL(即$_SERVER["REQUEST_URI"]),但设置默认值的右边只能为常量,所以该默认值设为空字符串,在函数内部再设置为本页URL。 function pageft($totle,$displaypg=20,$url=''){ //定义几个全局变量: //$page:当前页码; //$firstcount:(数据库)查询的起始项; //$pagenav:页面导航条代码,函数内部并没有将它输出; //$_SERVER:读取本页URL“$_SERVER["REQUEST_URI"]”所必须。 global $page,$firstcount,$pagenav,$_SERVER; //为使函数外部可以访问这里的“$displaypg”,将它也设为全局变量。注意一个变量重新定义为全局变量后,原值被覆盖,所以这里给它重新赋值。 $GLOBALS["displaypg"]=$displaypg; if(!$page) $page=1; //如果$url使用默认,即空值,则赋值为本页URL: if(!$url){ $url=$_SERVER["REQUEST_URI"];} //URL分析: $parse_url=parse_url($url); $url_query=$parse_url["query"]; //单独取出URL的查询字串 if($url_query){ //因为URL中可能包含了页码信息,我们要把它去掉,以便加入新的页码信息。 //这里用到了正则表达式,请参考“PHP中的正规表达式” $url_query=ereg_replace("(^|&)page=$page","",$url_query); //将处理后的URL的查询字串替换原来的URL的查询字串: $url=str_replace($parse_url["query"],$url_query,$url); //在URL后加page查询信息,但待赋值: if($url_query) $url.="&page;"; else $url.="page"; }else { $url.="?page"; } //页码计算: $lastpg=ceil($totle/$displaypg); //最后页,也是总页数 $page=min($lastpg,$page); $prepg=$page-1; //上一页 $nextpg=($page==$lastpg ? 0 : $page+1); //下一页 $firstcount=($page-1)*$displaypg; //开始分页导航条代码: $pagenav="显示第 <B>".($totle?($firstcount+1):0)."</B>-<B>".min($firstcount+$displaypg,$totle)."</B> 条记录,共 $totle 条记录"; //如果只有一页则跳出函数: if($lastpg<=1) return false; $pagenav.=" <a href='$url=1'>首页</a> "; if($prepg) $pagenav.=" <a href='$url=$prepg'>上一页</a> "; else $pagenav.=" 上一页 "; if($nextpg) $pagenav.=" <a href='$url=$nextpg'>下一页</a> "; else $pagenav.=" 下一页 "; $pagenav.=" <a href='$url=$lastpg'>尾页</a> "; //下拉跳转列表,循环列出所有页码: $pagenav.=" 到第 <select name='topage' size='1'>\n"; for($i=1;$i<=$lastpg;$i++){ if($i==$page) $pagenav.="<option value='$i' selected>$i</option>\n"; else $pagenav.="<option value='$i'>$i</option>\n"; } $pagenav.="</select> 页,共 $lastpg 页"; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值