使用PHP处理数据库数据如何将数据返回客户端并显示当前状态


Posted in PHP onFebruary 16, 2016

php处理大量数据,每处理一个数据返回客户端显示当前状态的方法。

类似于dedecms生成静态页

想法:

1.客户端发送请求
2.服务器端接受请求,开始统计所需处理的数据量
3.将所需处理数据按一定规则排列,发送到服务器处理端
4.服务器处理端处理了第一个数据,将处理结果经过一定处理后发送给客户端
5.客户端接收到结果,自动将处理结果显示并发送到服务器
6.服务器接收到处理结果 将它转发到服务器处理端
7.处理端继续处理结果...
8.循环4-7步骤,直到处理完毕

实验过程:

1.创建数据库和表

create databases handle;
create table user(
id int unsigned not null auto_increment primary key,
name varchar(8),
sex tinyint(1) default '1',
score int not null,
state tinyint(1)
);

2.向表中添加数据(不示例)

3.创建index.html客户端,a.php服务端1,b.php服务端2

Index.html:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>客户端</title>
</head>
<body>
<button onclick="send('a.php?state=0')">开始请求</button>
<div style="position: fixed;width: 500px;height: 300px;top: 100px;background: gray">
<span style="color: white;font-size: 20px;"></span>
</div>
<script type="text/javascript" src="./jquery-1.10.2.min.js"></script>
<script type="text/javascript">
//创建一个模态框
function display(value){
$('span').html(value);
}
//ajax
function send(dizhi){
$.ajax({
type: "get",
url: dizhi,
success: function(msg){
var arr=JSON.parse(msg);
console.log(arr);
//alert(arr.value);
var tishi="已经处理 "+arr.now +"个,共"+arr.all+"个";
display(tishi);
if(arr.now!=arr.all){
send("a.php?now="+arr.now+"&all="+arr.all);
}else{
alert("完成!");
}
}
});
}
</script>
</body>
</html>

a.php:

<?php
require('./dbconfig.php');
$link=mysql_connect(HOST,USER,PASS) or die('数据库链接失败');
mysql_select_db(DBNAME);
/*
查询数据
$sql="select * from user";
$result=mysql_query($sql);
$row=mysql_fetch_assoc($result);
var_dump($row);
*/
/*
循环插入
for($i=3;$i<=100;$i++){
$sql= "insert into user(name,score,state) values('z".$i."',".$i.",1)";
mysql_query($sql);
}
*/
/*查询需要处理的数据总数*/
//isset($_GET['state'])?$_GET['state']:0;
if(isset($_GET['state'])){
$sql="select count(*) from user";
$result=mysql_query($sql);
$all=mysql_result($result,0);
$now=0;
header("Location: b.php?all={$all}&now=0");
}else{
header("Location: b.php?all={$_GET['all']}&now={$_GET['now']}");
}
/*返回当前处理的数据*/

b.php:

<?php
require('./dbconfig.php');
$link=mysql_connect(HOST,USER,PASS) or die('数据库链接失败');
mysql_select_db(DBNAME);
/*返回当前处理的数据*/
//$id=$_GET['id'];//获取将要处理的id
$now=$_GET['now'];//已经处理的个数
$all=$_GET['all'];//总共要处理的个数
$sql="select score from user limit {$now},1";
$result=mysql_query($sql);
$value=mysql_result($result, 0);
$now++;
$arr=array(
'now'=>$now,
'all'=>$all,
'value'=>$value
);
//print_r($arr);
echo json_encode($arr);

dbconfig.php:

<?php
define('HOST','127.0.0.1');
define('USER', 'root');
define('PASS','root');
define('DBNAME','handle');

以上所述是小编给大家分享的使用PHP处理数据库数据如何将数据返回客户端并显示当前状态,希望对大家有所帮助!

PHP 相关文章推荐
玩转虚拟域名◎+ .
Oct 09 PHP
php array_flip() 删除数组重复元素
Jan 14 PHP
PHP 身份证号验证函数
May 07 PHP
PHP 学习路线与时间表
Feb 21 PHP
如何使用纯PHP实现定时器任务(Timer)
Jul 31 PHP
提高php编程效率技巧
Aug 13 PHP
适合PHP初学者阅读的4本经典书籍
Sep 23 PHP
iOS+PHP注册登录系统 PHP部分(上)
Dec 26 PHP
Laravel框架定时任务2种实现方式示例
Dec 08 PHP
PHP 观察者模式深入理解与应用分析
Sep 25 PHP
php pdo连接数据库操作示例
Nov 18 PHP
php 使用ActiveMQ发送消息,与处理消息操作示例
Feb 23 PHP
PHP的Yii框架入门使用教程
Feb 15 #PHP
在Mac OS的PHP环境下安装配置MemCache的全过程解析
Feb 15 #PHP
ThinkPHP设置禁止百度等搜索引擎转码(简单实用)
Feb 15 #PHP
ECshop 迁移到 PHP7版本时遇到的兼容性问题
Feb 15 #PHP
PHP扩展迁移为PHP7扩展兼容性问题记录
Feb 15 #PHP
PHP+MySQL统计该库中每个表的记录数并按递减顺序排列的方法
Feb 15 #PHP
在Mac OS上搭建PHP的Yii框架及相关测试环境
Feb 14 #PHP
You might like
微信公众号点击菜单即可打开并登录微站的实现方法
2014/11/14 PHP
PHP中生成UUID自定义函数分享
2015/06/10 PHP
解决nginx不支持thinkphp中pathinfo的问题
2015/07/21 PHP
用php和jQuery来实现“顶”和“踩”的投票功能
2016/10/13 PHP
详解thinkphp实现excel数据的导入导出(附完整案例)
2016/12/29 PHP
基于Laravel 5.2 regex验证的正确写法
2019/09/29 PHP
ASP.NET jQuery 实例5 (显示CheckBoxList成员选中的内容)
2012/01/13 Javascript
jQuery操作Select的Option上下移动及移除添加等等
2013/11/18 Javascript
js取float型小数点后两位数的方法
2014/01/18 Javascript
IE浏览器不支持getElementsByClassName的解决方法
2014/08/27 Javascript
在jQuery中使用$而避免跟其它库产生冲突的方法
2015/08/13 Javascript
JavaScript知识点总结之如何提高性能
2016/01/15 Javascript
基于Vue实现支持按周切换的日历
2020/09/24 Javascript
AngularJS路由删除#符号解决的办法
2017/09/28 Javascript
vue通过滚动行为实现从列表到详情,返回列表原位置的方法
2018/08/31 Javascript
JS使用队列对数组排列,基数排序算法示例
2019/03/02 Javascript
js canvas实现5张图片合成一张图片
2019/07/15 Javascript
JS运算符简单用法示例
2020/01/19 Javascript
Vue双向数据绑定(MVVM)的原理
2020/10/03 Javascript
[30:37]【全国守擂赛】第三周擂主赛 Dark Knight vs. Leopard Gaming
2020/05/04 DOTA
Python多进程并发(multiprocessing)用法实例详解
2015/06/02 Python
深入学习Python中的装饰器使用
2016/06/20 Python
关于django 数据库迁移(migrate)应该知道的一些事
2018/05/27 Python
PyQt4编程之让状态栏显示信息的方法
2019/06/18 Python
在Python中字符串、列表、元组、字典之间的相互转换
2019/11/15 Python
PyTorch 中的傅里叶卷积实现示例
2020/12/11 Python
Python项目打包成二进制的方法
2020/12/30 Python
CSS3制作Dropdown下拉菜单的方法
2015/07/18 HTML / CSS
美国医疗用品、医疗设备和家庭保健用品商店:Medical Supply Depot
2018/07/08 全球购物
董事长秘书岗位职责
2013/11/29 职场文书
优秀党员获奖感言
2014/02/18 职场文书
大学活动总结范文
2014/04/29 职场文书
童年读书笔记
2015/06/26 职场文书
学习师德师风的心得体会(2篇)
2019/10/08 职场文书
css中:last-child不生效的解决方法
2022/08/05 HTML / CSS
鸿蒙3.0体验感怎么样? 鸿蒙3.0系统评测向
2022/08/14 数码科技