gpt4 book ai didi

php - 使用正则表达式删除存储的 apc key

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:42:07 24 4
gpt4 key购买 nike

是否可以使用一种方法使您能够使用正则表达式删除存储的 apc 条目?

例如,当新数据输入数据库时​​,我想从缓存中删除一些用户查询,以便在下次运行查询时显示新数据。

假设您有一个缓存的好友列表查询,但是当添加新好友时,该用户的所有缓存好友查询都将被删除......

如果我有这样的用户好友列表键:

$sql = "SELECT * FROM friends WHERE userId = :userId";

$sqlKey = str_replace(":userId", $userId, $sql);
$key = $userId."-friend".md5('query'.$sqlKey);

$data = friendsArray;
apc_add($key, $data, 60 * 10);

然后期望的结果是在运行添加新 friend 查询后删除所有以当前 userId 开头的条目,以确保 friend 列表在下次查看时显示新用户:

apc_delete("~$userId-friend([a-f0-9]+)~");

由于好友列表 sql 和添加好友 sql 在不同的文档中,这似乎是无需重写和键入 sql 的最简单方法,但我认为不支持正则表达式?

最佳答案

作为J Fox wrote on php.net , apc_delete 还接受键数组或 APCIterator 对象。 APCIterator 接受正则表达式。所以你的代码应该看起来像这样:

// delete all keys beginning with a regex match
$toDelete = new APCIterator('user', '/^' . $userId . '-friend([a-f0-9]+)/', APC_ITER_VALUE);

var_dump( apc_delete($toDelete) );
// returns boolean true|false on success or failure

关于php - 使用正则表达式删除存储的 apc key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11515579/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com