php中memcache 基本操作实例

5年以前  |  阅读数:930 次  |  编程语言:PHP 

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分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例