mysql+redis+ajax简单获取数据实例

<?php 
header("content-type:text/html;charset=utf8");
//version 1
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$arr = $redis->get('data_from_class_all');
if(!empty($arr)){
  $data = $arr;
}
else{
  $dsn = "mysql:host=localhost;dbname=demo";
  $db = new PDO($dsn, 'root', '');
  $db->query("set names utf8");
  $data=$db->query('select * from `type`')->fetchAll(PDO::FETCH_ASSOC); 
  if(!empty($data)){
    $redis->set('data_from_class_all',$data);
  }

}

//version 2
$data = getData();
print_r($data);die;


//获取数据
function getData(){
  // to do somthing...
  $redisObj = getRedisInstance();
  $redisData = getRedisStr($redisObj, 'data_from_class_all');
  if(!empty($redisData)){
    $data = $redisData;
  }else{
    $db = getMysqlInstance();
    $data = getMysqlDataAll($db);
    if(!empty($data)){
      setRedisStr($redisObj, 'data_from_class_all', serialize($data));
    }
  }


  return $data;
}


// 获取redis实例
function getRedisInstance(){
  $redis = new Redis();
  $redis->connect('127.0.0.1', 6379);


  return $redis;
}


// 设置Redis的string类型值
function setRedisStr($redisObj, $redisKey, $data){
  $redisObj->set($redisKey,$data);
}




// 获取Redis的string类型值
function getRedisStr($redisObj, $redisKey){
  $redisData = $redisObj->get($redisKey);
  return unserialize($redisData);
}


// 获取mysql的实例
function getMysqlInstance(){
  $dsn = "mysql:host=localhost;dbname=demo";
  $db = new PDO($dsn, 'root', '');
  $db->query("set names utf8");


  return $db;
}


// 获取mysql的数据
function getMysqlDataAll($db){
  return $db->query('select * from `type`')->fetchAll(PDO::FETCH_ASSOC);
}

?>

<!DOCTYPE <html></html>
<html>
<head>
<link rel="stylesheet" type="text/js" href="./jquery-1.7.2.js">
<script type="text/javascript" src="./jquery-1.7.2.js"></script>
<title>分类展示</title>
</head>
<body>
<dl>
<?php for ($i=0; $i <count($data) ; $i++) { ?>
<a οnclick="zs('<?php echo $data[$i]['t_id']?>')"><?php echo $data[$i]['title'] ?></a> <br>
<?php } ?>  
</dl>
<span id="box1"></span>
</body>
</html>
<script type="text/javascript">
function zs(id){
$.ajax({
   type: "POST",
   url: "select.php",
   data: "id="+id,
   success: function(msg){
   var box="";
   var jsonReturn = eval("("+msg+")");
   for(var i=0;i<jsonReturn.length;i++){
    box=box+"<li>";
     for(var key in jsonReturn[i]){
             box=box+jsonReturn[i][key]+"&nbsp;&nbsp;&nbsp;&nbsp;";
     }
     box=box+"</li>";
    }
   $("#box1").html(box);
}
});
}
</script>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值