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. Java泛型中的协变和逆变

    Java泛型中的协变和逆变 一般我们看Java泛型好像是不支持协变或逆变的,比如前面提到的List<Object>和List<String>之间是不可变的.但当我们在Java泛 ...

  2. swift 即使不使用oc的动态派发机制也应该借鉴isa类型识别机制

    目前的消息派发机制真的很鸡肋. 简直是一堆狗屎. 类型信息中包含所有需要动态派发的函数:这个包含两类:类和protocol: 在编译时,首先搜索动态派发列表: 动态派发列表没有,在搜索静态派发列表: ...

  3. python 内置2to3工具将python2代码转换为python3代码

    python2与python3代码不兼容,如果需要python2代码在python3环境下运行,需要将代码进行转换,本文介绍使用python3内置工具2to3.py对代码进行转换 一:2to3.py在 ...

  4. cp - 复制文件和目录

    总览 cp [选项] 文件路径 cp [选项] 文件...目录 POSIX 选项: [-fipRr] GNU 参数(最短形式): [-abdfilprsuvxPR] [-S SUFFIX] [-V { ...

  5. [转]解决右键用notepad++打开提示【ShellExecute failed (2): Is this command Correct? (Fix) 】

    最近发现右键使用notepad++打开文件时提示如下错误: ShellExecute failed (2): Is this command Correct? ... 经用搜索引擎搜索得知,应该是开启 ...

  6. 根据数据库表自动生成实体类、xml和dao---mybatis

    网盘链接: https://pan.baidu.com/s/1AVGz0bDa_Y5zjk7vXa2eHw 提取码: 2gr6 1.记事本打开generatorConfig.xml文件 2(1,2,3 ...

  7. DTD DOCTYPE

    总结: DOCTYPE是什么 ? 文档类型声明,告诉解析器用什么样的文档类型定义来解析此文档.DOCTYPE不存在或格式不正确会导致文档以兼容模式呈现.   标准模式与兼容模式各有什么区别? 如果页面 ...

  8. Centos6.8 安装mongo3.6以及权限配置和开启外网链接

    目录 安装环境和版本说明,以及参考文档链接 安装MongoDB数据库 运行MongoDB数据库 删除卸载MongoDB 配置MongoDB管理员用户 修改配置文件,允许外网链接 安装配置完成,使用Ro ...

  9. 零基础入门学习Python(29)--文件:一个任务

    知识点 一个任务:将文件(record.txt)中的数据进行分割并按照以下规律保存起来: #record.txt文件内容: 小客服:小甲鱼,今天有客户问你有没有女朋友? 小甲鱼:咦?? 小客服:我跟她 ...

  10. 合并多个MP4文件

    把多个MP4文件连接起来的方法与音频文件不太一样,比较有效的方法是: $ cat mylist.txt file '/path/to/file1' file '/path/to/file2' file ...