数据库的东西可多了,
显示数据,查寻,分页等等!!!
这里来个分页的吧。
<?php
class page{
/*
实例:
$sql = "select count(*) from t_article";
$db->query($sql);
$db->next_record();
$recordcount = $db->f(0);//记录总数
$ofun = new page;
$ofun->pagearg = "pagenum";//设置分页参数名,默认为page
$ofun->ar = array("«首页", "‹前页", "后页›", "末页»");//可以设置成图片HTML代码
$trunpage = $ofun->show_page($recordcount, 20);//得到分页信息
$sql = "select * from t_article order by tdate desc ".$ofun->limit;
$db->query($sql);
*/ var $pagecount; //总页数
var $limit = ""; //分页时用到的limit参数
var $pagearg = "page"; //分页参数名称
var $ar = array("«首页", "‹前页", "后页›", "末页»");
/*
* 功能:分页函数
* 参数 $recordcount 为记录总数
* 参数 $pagesize 为每页显示记录数,默认为20
*/
function show_page($recordcount, $pagesize = 20){
$this->pagecount = ceil($recordcount/$pagesize);//总页数
//取得页码,默认为1
if(isset($_GET[$this->pagearg])){
if($_GET[$this->pagearg] <= 0) $page = 1;
else $page = $_GET[$this->pagearg];
}else {
$page = 1;
}
$str = "";
$urlar = $_GET;
unset($urlar[$this->pagearg]);
if($urlar){
foreach($urlar as $key=>$val){
if($str == "") $str = "?$key=$val";
else $str .= "&$key=$val";
}
$str .= "&$this->pagearg=";
}else{
$str = "?$this->pagearg=";
}
if($page > $this->pagecount) $page = $this->pagecount;
$this->limit = "limit ".($page-1)*$pagesize.",".$pagesize;
$trunpage = "";
if($page == 1){
$trunpage .= $this->ar[0]." ".$this->ar[1]." ";
}else {
$trunpage .= '<a href="'.$str.'1">'.$this->ar[0].'</a> <a href="'.$str.($page-1).'">'.$this->ar[1].'/a> ';
}
$trunpage .= " 共[$recordcount]条记录/共[$this->pagecount]页 ";
if($page == $this->pagecount){
$trunpage .= $this->ar[2]." ".$this->ar[3]." ";
}else {
$trunpage .= ' <a href="'.$str.($page+1).'">'.$this->ar[2].'</a> <a href="'.$str.$this->pagecount.'">'.$this->ar[3].'</a>';
}
$select = "<select onchange='location.href=this.options[this.selectedIndex].value'>\n";
for($i = 1; $i <= $this->pagecount; $i++){
$select .= "<option value=\"".$str.$i."\">$i</option>\n";
}
$select .= "</select>";
return $trunpage.$select;
}
}
?>
显示数据,查寻,分页等等!!!
这里来个分页的吧。
<?php
class page{
/*
实例:
$sql = "select count(*) from t_article";
$db->query($sql);
$db->next_record();
$recordcount = $db->f(0);//记录总数
$ofun = new page;
$ofun->pagearg = "pagenum";//设置分页参数名,默认为page
$ofun->ar = array("«首页", "‹前页", "后页›", "末页»");//可以设置成图片HTML代码
$trunpage = $ofun->show_page($recordcount, 20);//得到分页信息
$sql = "select * from t_article order by tdate desc ".$ofun->limit;
$db->query($sql);
*/ var $pagecount; //总页数
var $limit = ""; //分页时用到的limit参数
var $pagearg = "page"; //分页参数名称
var $ar = array("«首页", "‹前页", "后页›", "末页»");
/*
* 功能:分页函数
* 参数 $recordcount 为记录总数
* 参数 $pagesize 为每页显示记录数,默认为20
*/
function show_page($recordcount, $pagesize = 20){
$this->pagecount = ceil($recordcount/$pagesize);//总页数
//取得页码,默认为1
if(isset($_GET[$this->pagearg])){
if($_GET[$this->pagearg] <= 0) $page = 1;
else $page = $_GET[$this->pagearg];
}else {
$page = 1;
}
$str = "";
$urlar = $_GET;
unset($urlar[$this->pagearg]);
if($urlar){
foreach($urlar as $key=>$val){
if($str == "") $str = "?$key=$val";
else $str .= "&$key=$val";
}
$str .= "&$this->pagearg=";
}else{
$str = "?$this->pagearg=";
}
if($page > $this->pagecount) $page = $this->pagecount;
$this->limit = "limit ".($page-1)*$pagesize.",".$pagesize;
$trunpage = "";
if($page == 1){
$trunpage .= $this->ar[0]." ".$this->ar[1]." ";
}else {
$trunpage .= '<a href="'.$str.'1">'.$this->ar[0].'</a> <a href="'.$str.($page-1).'">'.$this->ar[1].'/a> ';
}
$trunpage .= " 共[$recordcount]条记录/共[$this->pagecount]页 ";
if($page == $this->pagecount){
$trunpage .= $this->ar[2]." ".$this->ar[3]." ";
}else {
$trunpage .= ' <a href="'.$str.($page+1).'">'.$this->ar[2].'</a> <a href="'.$str.$this->pagecount.'">'.$this->ar[3].'</a>';
}
$select = "<select onchange='location.href=this.options[this.selectedIndex].value'>\n";
for($i = 1; $i <= $this->pagecount; $i++){
$select .= "<option value=\"".$str.$i."\">$i</option>\n";
}
$select .= "</select>";
return $trunpage.$select;
}
}
?>
PHP手册是个好东西,但是相比起来实作的经验和相互的交流更重要,上CSDN的朋友未必水平都一样,熟悉和精通的方向也不一样,开一系列集思广益的帖子,高手们多上一些实作的程序和个人的心得、体会、技巧,我认为这对大家都是有帮助的。
以下是自己对数据库的一些感受,
1. 数据库连接,如果考虑的数据库连接性能,如果访问量较多,可考虑使用永久性连接,这样对于提高程序整体性能非常有意义
2. 对于返回多行的结果集,最好不要一次将所有结果全部都出,尤其对于oracle,另外如果只返回一行结果(多数情况),不要使用二维数组,这样PHP执行效率会有明显提升。
3. 最好不要使用某一数据库的特殊特性,这样不利于代码移植.
4. 如果是开发大型项目,而数据库移植的可能性也几乎没有,这样可能需要自己写一些数据库处理的类,对充分发挥数据库特性非常有用
你指的是 数据库原理?某一具体的数据库产品?还是PHP+数据库?
你可以根据楼上 runmin(阮) 兄讲得原理中,可以分别查看你所感兴趣的数据库产品的帮助文档