php中memcache 基本操作实例


Posted in PHP onMay 17, 2015

php中memcache 基本操作实例

<!DOCTYPE html>
<html>
<head>
<title>memcache demo</title>
<meta http-equiv="content-type"content="text/html;chatset=utf-8">
</head>
<body>
<?php
$server_ip = '127.0.0.1';
$server_port = 11211;

$memcache = new Memcache();
$memcache->connect($server_ip,$server_port);

$memcache->add("name1","user_name1",MEMCACHE_COMPRESSED,0);
$memcache->add("name2","user_name2",MEMCACHE_COMPRESSED,0);
$array1 = array('name1' => 'jiajiam1', 
'age1'=>12,
'country'=>'china');
$memcache->add("other",$array1,MEMCACHE_COMPRESSED,20);
$memcache->set("name3","user_name3",MEMCACHE_COMPRESSED,0);
$memcache->replace("name1","user_name_relpace",MEMCACHE_COMPRESSED,0);
$memcache->replace("123","12345");

echo"name1:".$memcache->get("name1")."<br/>";
$memcache->delete("name1");
echo"name1:".$memcache->get("name1")."<br/>";

$array_get = array("name1","name2","name3");

$result_get = $memcache->get($array_get);
foreach ($result_get as $key => $value) {
echo"$key:--->$value<br/>";
}
foreach ($memcache->getStats() as $key => $value) {
echo"$key:--->$value<br/>";
};

echo"<br/>";

foreach($memcache->getExtendedStats() as $key => $value) {
echo"$key:--->$value<br/>";
}
$memcache->close();
?>
</body>
</html>

我们再来看个更加具体些的实例

<?php
include('inc/common.inc.php');

if (! isset($city) || ! is_array($city) ) {
	exit;
}

//print_r ($city);exit;

$mem = new Memcache();
$mem-> connect('localhost', '11211');
$expires=15*60;

//check if cache exits
if(($value = $mem-> get($city)) != FALSE) {
	echo "get key from memcache: "."<br />";
	// 	$return=$mem->get($city);
	// 	echo json_encode($return);
}//if
else {
	$resultJson=fetch_data();
	echo count($resultJson)."<br />";
	if(count($resultJson)==1 || empty($resultJson)){
		//从mysql中取值
		echo "get key from mysql:"."<br />";
		$query="select * from pm25";
		$result=mysql_query ($query) ;
		while ($row = mysql_fetch_assoc($result)){
			$rows[]=$row;
		}
		//将获取的值数组存入memcache
		for($i=0;$i<count($rows);$i++){
			$k[$i]=$rows[$i]['city'];
			$v[$i]['city']=$rows[$i]['city'];
			$v[$i]['pm25']=$rows[$i]['pm25'];
			$mem -> set($k[$i], $v[$i], false, $expires);
		}
		// 		$return=$mem->get($city);
		// 		echo json_encode($return);
	}//if
	else{
		echo "get key from new_writed mysql:"."<br />";
		write_db($resultJson);
		$query="select * from pm25";
		$result=mysql_query ($query) ;
		while ($row = mysql_fetch_assoc($result)){
			$rows[]=$row;
		}
		//write memcache
		for($i=0;$i<count($rows);$i++){
			$k[$i]=$rows[$i]['city'];
			$v[$i]['city']=$rows[$i]['city'];
			$v[$i]['pm25']=$rows[$i]['pm25'];
			$mem -> set($k[$i], $v[$i], false, $expires);
		}
		// 		$return=$mem->get($city);
		// 		echo json_encode($return);
	}//else

}//else

foreach ($city as $k=>$v){
	$return[$k]=$mem->get($v);
}
echo json_encode($return);

function fetch_data() {
	$url="http://www.example.com";
	//$url="";	
	$data = http_get($url);
	$getJson = json_decode($data, true);
	return $getJson;
} //func fetch_data

function write_db($getJson){
	$sql="DELETE FROM pm25";
	mysql_query($sql);
	//sort the json.txt
	foreach ($getJson as $key => $row) {
		$area[$key] = $row['area'];
		$pm2_5[$key]= $row['pm2_5'];
	}
	array_multisort($area, SORT_ASC,$pm2_5,SORT_ASC,$getJson);
	for($i=0;$i<count($getJson)-1;$i++){
		if($getJson[$i]['pm2_5']==0)
			$count=0;
		else
			$count=1;
		$sum=$getJson[$i]['pm2_5'];
		for($j=$i+1;$j<count($getJson);$j++,$i++){
			if(strcmp($getJson[$j]['area'],$getJson[$i]['area'])==0 ){
				if($getJson[$j]['pm2_5']==0 ){
					continue;
				}
				else{
					$count++;
					$sum+=$getJson[$j]['pm2_5'];
					$pm2_5=$sum/$count;
				}
			}
			else{
				//insert into mysql
				$result['city']=$getJson[$i]['area'];
				$result['pm25']=intval($pm2_5);
				$query="insert into pm25(city,pm25) values ('".$result['city']."',".$result['pm25'].")";
				mysql_query($query);
				break;
			}
		}
	}
	return $getJson;
}//func write_db


$mem -> close();
?>

以上所述就是本文的全部内容了,希望大家能够喜欢。

PHP 相关文章推荐
CURL状态码列表(详细)
Jun 27 PHP
php的sso单点登录实现方法
Jan 08 PHP
php返回相对时间(如:20分钟前,3天前)的方法
Apr 14 PHP
php基于单例模式封装mysql类完整实例
Oct 18 PHP
利用php-cli和任务计划实现刷新token功能的方法
May 03 PHP
PHP实现模拟http请求的方法分析
Dec 20 PHP
PHP实现通过strace定位故障原因的方法
Apr 29 PHP
php empty 函数判断结果为空但实际值却为非空的原因解析
May 28 PHP
PHP切割汉字的常用方法实例总结
Apr 27 PHP
thinkPHP5.1框架路由::get、post请求简单用法示例
May 06 PHP
PHP实现新型冠状病毒疫情实时图的实例
Feb 04 PHP
PHP实现过滤各种HTML标签
May 17 #PHP
支持中文的PHP按字符串长度分割成数组代码
May 17 #PHP
php 批量查询搜狗sogou代码分享
May 17 #PHP
PHP解密Unicode及Escape加密字符串
May 17 #PHP
PHP实现远程下载文件到本地
May 17 #PHP
PHP生成json和xml类型接口数据格式
May 17 #PHP
php实现文本数据导入SQL SERVER
May 17 #PHP
You might like
第七节--类的静态成员
2006/11/16 PHP
实现PHP框架系列文章(6)mysql数据库方法
2016/03/04 PHP
php实现的一段简单概率相关代码
2016/05/30 PHP
IE 缓存策略的BUG的解决方法
2007/07/21 Javascript
JavaScript高级程序设计 阅读笔记(十八) js跨平台的事件
2012/08/14 Javascript
提交表单时执行func方法实现代码
2013/03/17 Javascript
javascript基础之查找元素的详细介绍(访问节点)
2013/07/05 Javascript
JS弹出可拖拽可关闭的div层完整实例
2015/02/13 Javascript
在js里怎么实现Xcode里的callFuncN方法(详解)
2016/11/05 Javascript
对比分析Django的Q查询及AngularJS的Datatables分页插件
2017/02/07 Javascript
Vue2.0 axios前后端登陆拦截器(实例讲解)
2017/10/27 Javascript
Vue工程模板文件 webpack打包配置方法
2017/12/26 Javascript
vue引入js数字小键盘的实现代码
2018/05/14 Javascript
Vue不能观察到数组length的变化
2018/06/08 Javascript
解决vue router组件状态刷新消失的问题
2018/08/01 Javascript
Vue 与 Vuex 的第一次接触遇到的坑
2018/08/16 Javascript
小程序指纹验证的实现代码
2018/12/04 Javascript
JavaScript常见鼠标事件与用法分析
2019/01/03 Javascript
vue实现的请求服务器端API接口示例
2019/05/25 Javascript
解决使用layui对select append元素无效或者未及时更新的问题
2019/09/18 Javascript
Vue组件通信中非父子组件传值知识点总结
2019/12/05 Javascript
原生JS实现相邻月份日历
2020/10/13 Javascript
[01:03:51]2018DOTA2亚洲邀请赛 4.7 淘汰赛 VP vs LGD 第三场
2018/04/09 DOTA
pandas通过索引进行排序的示例
2018/11/16 Python
Python操作远程服务器 paramiko模块详细介绍
2019/08/07 Python
tensorflow estimator 使用hook实现finetune方式
2020/01/21 Python
python deque模块简单使用代码实例
2020/03/12 Python
python爬虫实例之获取动漫截图
2020/05/31 Python
美国美发品牌:Bumble and Bumble
2016/10/08 全球购物
编辑硕士自荐信范文
2013/11/27 职场文书
前台文员个人求职信范文
2014/01/05 职场文书
建筑管理专业求职信
2014/07/28 职场文书
乡镇挂职心得体会
2014/09/04 职场文书
药店营业员岗位职责
2015/04/14 职场文书
增值税发票丢失证明
2015/06/19 职场文书
JavaScript原型链中函数和对象的理解
2022/06/16 Javascript