mysql.php 获取数据库中的记录,全然个人经验总结,仅供參考!

<?

php

/**

*PHP+MYSQL数据库基本功能

*http://blog.csdn.net/yown

*/

############################################

#获取序列ID

############################################

function getSequence() {

$sql = "update sequence set id=last_insert_id(id+1);";

$sql2= "select last_insert_id();";



global $dbuser,$dbpass,$host,$database,$printsql;



$link = mysql_connect($host,$dbuser,$dbpass);

if(! $link){

  return mysql_error();

}



mysql_select_db($database);

mysql_query("SET NAMES UTF8"); 

if($printsql) echo "<hr/>".$sql."<hr/>";

mysql_query($sql);

if($printsql) echo "<hr/>".$sql2."<hr/>";

$result = mysql_query($sql2);



if(mysql_num_rows($result)==0){

  mysql_close($link);

  return "";

}

$myrow = mysql_fetch_row($result);

$ret=$myrow[0];



mysql_close($link);

return $ret;

}

############################################

#获取strSql第N条记录中的第N列数据,下标从1開始

############################################

function getData($strsql,$row,$col) {

global $dbuser,$dbpass,$host,$database,$printsql;



$link = mysql_connect($host,$dbuser,$dbpass);

if(! $link){

  return mysql_error();

}



mysql_select_db($database);

mysql_query("SET NAMES UTF8"); 

if($printsql) echo "<hr/>".$strsql."<hr/>";

$result = mysql_query($strsql);



if(mysql_num_rows($result)==0){

  mysql_close($link);

  return "";

}

$i=0;

while($myrow = mysql_fetch_row($result)){



   if($i==$row-1){

      $ret=$myrow[$col-1];

      break;

   }

   $i=$i+1;

}



mysql_close($link);

return $ret;



}



############################################

#获取strSql第N条记录

############################################

function getRowData($strsql,$row) {

global $dbuser,$dbpass,$host,$database,$printsql;



$link = mysql_connect($host,$dbuser,$dbpass);

if(! $link){

  return mysql_error();

}



mysql_select_db($database);

mysql_query("SET NAMES UTF8"); 

if($printsql) echo "<hr/>".$strsql."<hr/>";

$result = mysql_query($strsql);



if(mysql_num_rows($result)==0){

  mysql_close($link);

  return "";

}

$i=0;

while($myrow = mysql_fetch_array($result)){



   if($i==$row-1){

      $ret=$myrow;

      break;

   }

   $i=$i+1;

}



mysql_close($link);

return $ret;



}



############################################

#获取strSql记录集存入数组中

############################################

function getResultSetData($strsql) {

global $dbuser,$dbpass,$host,$database,$printsql;



$link = mysql_connect($host,$dbuser,$dbpass);

if(! $link){

  return mysql_error();

}



mysql_select_db($database);

mysql_query("SET NAMES UTF8"); 

if($printsql) echo "<hr/>".$strsql."<hr/>";

$result = mysql_query($strsql);



if(mysql_num_rows($result)==0){

  mysql_close($link);

  return "";

}



while($myrow = mysql_fetch_array($result)){

      $ret[]=$myrow;     

}



mysql_close($link);

return $ret;

}



############################################

#运行strSql

############################################

function executeSql($strsql) {

global $dbuser,$dbpass,$host,$database,$printsql;



$link = mysql_connect($host,$dbuser,$dbpass);

if(! $link){

  return mysql_error();

}



mysql_select_db($database);

mysql_query("SET NAMES UTF8"); 

if($printsql) echo "<hr/>".$strsql."<hr/>";

mysql_query($strsql);

$ret =mysql_affected_rows($link);

mysql_close($link);

return $ret;

}



/*

 分页

*/

 function Pager(&$curpage,&$pagesize,&$tsql,&$psql,&$totalpage,&$totalrow,&$pagerset){



 $curpage=isset($curpage)?

intval($curpage):1;//当前页

 $totalpage=0;//总页数

 $totalrow=0;//总记录数

 if($printsql) echo "<hr/>".$tsql."<hr/>";

 if($curpage <= 0){

   $curpage=1;

 }

 

 $totalrow=getData($tsql,1,1);//取得总记录数

 $totalrow=strlen(totalrow)==0?

0:$totalrow; 

 if($totalrow>0){

   $totalpage=$totalrow%$pagesize==0?(int)($totalrow/$pagesize):(int)($totalrow/$pagesize)+1;

    if($curpage>$totalpage){

      $curpage=1;

   }

      

   $psql=$psql." limit ".(($curpage-1)*$pagesize).",".$pagesize;

    if($printsql) echo "<hr/>".$psql."<hr/>"; 

    $pagerset=getResultSetData($psql);//取得当前页记录

 }

 if($totalrow==0||$totalrow=="0"){ $curpage=1;}

 

}



?>

php高效获取数据分页的更多相关文章

  1. pandas | 如何在DataFrame中通过索引高效获取数据?

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是pandas数据处理专题的第四篇文章,我们一起来聊聊DataFrame中的索引. 上一篇文章当中我们介绍了DataFrame数据结构当 ...

  2. Statement和PreparedStatement的特点 MySQL数据库分页 存取大对象 批处理 获取数据库主键值

    1 Statement和PreparedStatement的特点   a)对于创建和删除表或数据库,我们可以使用executeUpdate(),该方法返回0,表示未影向表中任何记录   b)对于创建和 ...

  3. SQL Server 怎么在分页获取数据的同时获取到总记录数

    SQL Server 获取数据的总记录数,有两种方式: 1.先分页获取数据,然后再查询一遍数据库获取到总数量 2.使用count(1) over()获取总记录数量 SELECT * FROM ( SE ...

  4. redis分页获取数据

    php代码: 采用哈希类型存储数据,有序集合存储分页数据,进行倒序与正序的排序. $getGoodsInfo = M('goods_test')->select(); for($i=0;$i&l ...

  5. Mongoose 分页查询优化、获取数据总长度

    无论是传统网页还是 ajax api,我们都不得不进行数据分页,一来节省带宽二来提升页面响应速度.作为一个数据完备的 web 应用,做好分页功能能极大提升用户体验. 简单的分页查询 在 mongoos ...

  6. jquery datatable 获取当前分页的数据

    使用jquery datatable 遇到分页分别求和时,找了半天才找到获取当前分页数据的方法,以此总结 var table=$('#example').DataTable( { "pagi ...

  7. tp5 使用paginate分页获取数据对象之后 如何对对象进行数据添加

    tp5 使用paginate分页获取数据对象之后 如何对对象进行数据添加 大家都知道,在使用tp5的paginate获取分页数据之后,得到的是一个数据对象,但有时会碰到要对数据对象进行二次加工的情况, ...

  8. 腾讯云图片鉴黄集成到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 ...

  9. 【Django+Element UI】使用一个接口文件,搞定分页获取数据,模糊查询后分页获取数据

    1:序列化获取数据的接口设计 1:分页获取序列化数据 2:是个能传参数的接口 class Society(APIView): def post(self, request): keywords = s ...

随机推荐

  1. Android(java)学习笔记202:JNI之hello.c(c代码功能实现)指针语法解析

    1. 接下来我们细讲分析一下前面一讲中,c功能实现的代码: (1)hello.c : #include <jni.h> char* getHello() { //////// return ...

  2. java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了

    java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了 软件:idea 问题产生:其他同事进行开发,引入新java组件后提交 ...

  3. java_tcp_简单示例

    package netProgram; import java.io.DataOutputStream; import java.io.IOException; import java.net.Ser ...

  4. VS2008 ActiveX(ocx控件)的调试工具ActiveX Control Test Container安装说明

    vs2008中的TSTCON( ActiveX Control Test Container )工具非自动安装,而是作为一个例程提供.所以应找到该例程,并编译: 如vs2008安装在默认路径则 1, ...

  5. 除了上万的月薪之外,还有什么理由让我们必须学Python?

    虽然目前的编程语言有很多,但是基础语法上的概念,本质上都是相通的.可以做到一通百通.所以没有必要为了学哪门语言纠结太多. python是目前市面上,我个人认为是最简洁&&最优雅& ...

  6. switch、try-catch

    记录 1. 使用对象代替 switch 和 if-else 2. 根据返回数据是否能转成对象,取值 如果返回是数字字符串,直接返回,如果返回是对象,取对应的key值,再返回 其它情况,返回空 {{ o ...

  7. Linux基础学习二

    新建分区:fdisk /dev/sda(a代表第一块硬盘)                   建完后w保存 更新分区表:partprobe mkfs.ext4 /dev/sdb{1..3} : 格式 ...

  8. python字符串,常用编码

    Python的字符串和编码 1.常用编码 与python有关的编码主要有:ASCII.Unicode.UTF-8 其中ASCII如今可以视作UTF-8的子集 内存中统一使用Unicode编码(如记事本 ...

  9. Win2008 Server MySql安装包详细安装教程

    首先去官网下载 下载MySql 下载地址:http://downloads.mysql.com/archives/community/ 我这里选择MSI的32位安装包安装,服务器系统32位的. 安装M ...

  10. ecshop 修改支持php7 方案

    修改方法 http://jsb.php-php.com/2016/05/472/ 修改数据库配置 data/config.php