微擎数据库缓存的增、删、改和查函数详解

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
+关注继续查看

函数所在文件:framework/function/cache.mysql.func.php


目前微擎的个人真实调用:

$setting = $this->module['config'];

$aaaaa = $setting['copyright'];


在微擎微信公众号系统里面可以分为三类缓存:保存到数据库表core_cache中的数据库缓存、保存到文件的文件缓存和memcahe缓存,本教程介绍的是数据库缓存,也是微擎系统配置的默认缓存。


因为,处理数据库缓存的函数相对简单,所以,phpos微信网把这几个函数一起制作成一个教程。因为是对数据库表操作,所以,再怎么操作表,无非就是对表记录进行插入(增)、删除、修改和查询,所以,对应着数据库缓存函数也有插入缓存数据、删除缓存数据、修改缓存数据和查询缓存数据操作。


在微擎微信公众号系统里面缓存数据都保存到了缓存表core_cache里面,也就是说下面的函数都是对这个表这进行的增、删、改和查的操作。


表core_cache:

1.png


一、插入(写入)缓存数据


cache_write($key, $data)函数:这个在本站已经有详细的讲解了,这里不再多解释。


示例


load()->func('cache.mysql');

cache_write('phpos',array('webname'=>'微信开发','url'=>'phpos.net','title'=>array('微信开发','微信公众号')));


结果:


2.png


二、删除缓存数据


  删除函数:cache_delete($key)


  此函数的作用是:删除core_cache表中的某一条记录。


  $key 为要删除的表中字段key的值,例如,删除phpos记录,则$key='phpos'。


  这个函数使用的sql语句是:

DELETE FROM ' . tablename('core_cache') . ' WHERE `key`=:key


  这个参数$key正是要删除的条件,所以,只要您传一个值$key就可以把表中key字段对应的记录删除掉。


  在这个函数里面使用了微擎微信公众号系统封装的数据库查询函数pdo_query($sql, $params),这个函数类似面向过程里面的mysql_query()执行一条sql语句。


示例


删除字段phpos对应的记录:

load()->func('cache.mysql');

cache_delete('phpos');


三、删除整个缓存表里面的记录,或是删除包含相同名称的记录。


  删除函数:cache_clean($prefix = '')


  上面的函数是删除确定的某一条记录,而本函数删除的是整个表或是包含类似phpos:、web:、site:等字段的值的记录。


  1)如果$prefix为空,则删除事个core_cache表中的数据。


  并且,删除保存在全局变量$_W中的数据:

 

        if ($result) {

            unset($_W['cache']);

        }


  其中,$_W['cache']是在文件bootstrap.inc.php里面定义的:


if(!in_array($_W['config']['setting']['cache'], array('mysql', 'file', 'memcache'))) {

    $_W['config']['setting']['cache'] = 'mysql';

}

  这个条件里面的$_W['config']['setting']['cache']是在配置文件data/config.php配置的,默认是mysql,表示使用缓存数据使用“数据库缓存”。


  2)如果$prefix不空,则删除与{$prefix}:%匹配的数据。


示例:


load()->func('cache.mysql');

cache_clean('website');

cache_clean();


四、查询缓存数据


  1)读取缓存数据函数:


cache_read($key)

  读取表中某一条缓存数据的值:


SELECT `value` FROM ' . tablename('core_cache') . ' WHERE `key`=:key'


  从这个sql语句就可以看出这个函数查询的是表core_cache中的键为$key对应的值,并且,使用函数iunserializer($val)把查询出来的序列化的字符串转换成反序列化成字符串。


示例


load()->func('cache.mysql');

print_r(cache_read('website'));


结果:Array ( [url] => www.phpos.net [title] => 微信网 )

  2)查询所有符合条件的缓存数据函数:


cache_search($prefix)


  查询sql语句:


    $sql = 'SELECT * FROM ' . tablename('core_cache') . ' WHERE `key` LIKE :key';

    $params = array();

    $params[':key'] = "{$prefix}%";

    $rs = pdo_fetchall($sql, $params);


  从上面这段代码就可以看出这个函数是查询字段key的值包含{$prefix}的所有记录,这里使用了函数pdo_fetchall()查询出所有符合条件的记录。


  最后,返回的是$result,也是一个数组。


示例


load()->func('cache.mysql');

print_r(cache_search('website'));


结果:Array ( [website] => Array ( [url] => www.phpos.net [title] => 微信网 ) )

五、更新缓存数据

  在这个文件cache.mysql.func.php里面,我们并没有发现更新缓存数据,难道不能更新吗?其实,写数据函数cache_write()里面在调用函数pdo_insert('core_cache', $record, true)时,使用了插入数据函数的第三个参数true,如果使用这个参数,使用replace into语句插入数据,这条sql语句,会判断一下表中是否存在某一数据,如果存在则删除之,然后,再把要插入表的数据插入到表中。


所以,其实,这个写入数据函数本身就有更新数据的功能,所以,在这个文件里面并没有单独定义“更新”缓存数据。



本文转自 gutaotao1989 51CTO博客,原文链接:http://blog.51cto.com/taoyouth/2059171
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
关系型数据库 MySQL 数据库
MySQL数据表:对数据的基础操作(增、删、查、改)以及运算符的讲解
MySQL数据表:对数据的基础操作(增、删、查、改)以及运算符的讲解
53 1
|
4月前
|
存储
动态顺序表构建——增、删、查、改、自动扩容、功能的实现
动态顺序表构建——增、删、查、改、自动扩容、功能的实现
|
5月前
|
存储 Java Shell
分布式数据库HBase的常用操作的基本Shell命令的增/删/改/查
HBase是一个分布式数据库系统,支持高性能、可伸缩、实时的数据存储和处理。在HBase中,我们可以使用Shell命令来进行常用的操作,如创建表、插入数据、查询数据、更新数据等。本文将介绍关于分布式数据库HBase的常用操作基本Shell命令的增删改查。
276 0
|
5月前
|
SQL JavaScript 关系型数据库
nodejs:本地nodejs连接mysql 实现 增、删、改、查
nodejs:本地nodejs连接mysql 实现 增、删、改、查
77 0
|
6月前
|
SQL 存储 缓存
JDBC完成对数据库数据操作(增,删,改,查)
JDBC完成对数据库数据操作(增,删,改,查)
|
12月前
|
安全 关系型数据库 MySQL
mysql数据库的增、删、改、查
mysql数据库的增、删、改、查
72 0
mysql数据库的增、删、改、查
|
SQL Oracle Java
JDBC 完成增、删、改、查 | 学习笔记
快速学习JDBC 完成增、删、改、查。
JDBC 完成增、删、改、查 | 学习笔记
|
存储 SQL 关系型数据库
聊一聊 MYSQL 数据的真删和假删
聊一聊 MYSQL 数据的真删和假删
783 0
聊一聊 MYSQL 数据的真删和假删
|
关系型数据库 MySQL
【Elasticsearch】增、删、改、查操作深入详解
【Elasticsearch】增、删、改、查操作深入详解
92 0
【Elasticsearch】增、删、改、查操作深入详解
|
人工智能 JSON 关系型数据库
Mysql数据库 增、删、改、查 的操作
Mysql数据库 增、删、改、查 的操作