本文實(shí)例講述了thinkPHP5框架數(shù)據(jù)庫(kù)連貫操作之cache()用法。分享給大家供大家參考,具體如下:
介紹
TP5中自帶的緩存系統(tǒng),是File型緩存。也就是文件型緩存。存儲(chǔ)地址是:根目錄\..\runtime\cache(根目錄指public)。
這個(gè)緩存系統(tǒng)相較于redis,memcached肯定有局限性的,自動(dòng)更新以及緩存數(shù)據(jù)的復(fù)雜程度上有區(qū)別。但是對(duì)于一些簡(jiǎn)單的查詢等還有很有幫助的。比如文章等這些內(nèi)容使用起來(lái)還是不錯(cuò)的。
cache可以用于select、find、value和column方法,以及其衍生方法,使用cache方法后,在緩存有效期之內(nèi)不會(huì)再次進(jìn)行數(shù)據(jù)庫(kù)查詢操作,而是直接獲取緩存中的數(shù)據(jù),關(guān)于數(shù)據(jù)緩存的類型和設(shè)置可以參考緩存部分。
存儲(chǔ)cache
1. 簡(jiǎn)單的存儲(chǔ)
//查詢news表中id=10的新聞存儲(chǔ)于cache中,寫true默認(rèn)讀取配置的中緩存時(shí)間,db():助手函數(shù)
db('news')->cache(true)->find(10);
//你也可以自定義時(shí)間,60秒表示
db('news')->cache(true,60)->find(10);
2. 指定緩存標(biāo)識(shí)
//緩存標(biāo)識(shí)可以理解為鍵,就是當(dāng)你想要去取出緩存中的某條數(shù)據(jù)的令牌,id=15的存進(jìn)cache并且給定下標(biāo)為key
db('news')->cache('key')->find(15);
//當(dāng)你想要去取出id=15的這條數(shù)據(jù)時(shí)候
$data = \think\Cahce::get('key');
你可以在任何一個(gè)地方來(lái)讀取這條數(shù)據(jù),此處類似于session()
3. cache方法支持設(shè)置緩存標(biāo)簽
db('news')->cache('key',60,'tagName')->find(15);
更新cache
現(xiàn)在這么看有一個(gè)問(wèn)題,當(dāng)你的項(xiàng)目運(yùn)行了一段時(shí)間了豈不是會(huì)產(chǎn)生很多的緩存文件,文件越來(lái)越多,每次請(qǐng)求去找cache文件的時(shí)候浪費(fèi)的時(shí)間可能比直接查詢數(shù)據(jù)庫(kù)更慢。怎么辦呢?
TP5有一個(gè)cache自動(dòng)更新的方法。就是同數(shù)據(jù)有刪除或者更新操作的時(shí)候會(huì)自動(dòng)刪除掉老的緩存文件。
//查詢id=328的存進(jìn)cache
$list = db('news')->cache(true)->find(328);
//現(xiàn)在進(jìn)行測(cè)試下,你手動(dòng)去數(shù)據(jù)庫(kù)修改id=328的某個(gè)字段的值,然后再次進(jìn)行第一次的查詢請(qǐng)求發(fā)現(xiàn)數(shù)據(jù)庫(kù)修改的字段沒(méi)變,這時(shí)候就是讀取的緩存,然后
db('news')->update(['id'=>328,'title'=>'測(cè)試']);
//這時(shí)候你再次請(qǐng)求會(huì)發(fā)現(xiàn)獲取的數(shù)據(jù)改變了 ,這時(shí)候不再是讀取的緩存,因?yàn)槟阕隽烁虏僮?,重新寫進(jìn)緩存了,當(dāng)然,以上說(shuō)的這種情況前提是使用的主鍵查詢的
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- tp5.1 框架數(shù)據(jù)庫(kù)高級(jí)查詢技巧實(shí)例總結(jié)
- ThinkPHP5.1框架數(shù)據(jù)庫(kù)鏈接和增刪改查操作示例
- PHP利用pdo_odbc實(shí)現(xiàn)連接數(shù)據(jù)庫(kù)示例【基于ThinkPHP5.1搭建的項(xiàng)目】
- PHP7使用ODBC連接SQL Server2008 R2數(shù)據(jù)庫(kù)示例【基于thinkPHP5.1框架】
- thinkPHP5實(shí)現(xiàn)的查詢數(shù)據(jù)庫(kù)并返回json數(shù)據(jù)實(shí)例
- tp5(thinkPHP5)框架數(shù)據(jù)庫(kù)Db增刪改查常見(jiàn)操作總結(jié)
- tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)查詢的方法
- tp5(thinkPHP5)操作mongoDB數(shù)據(jù)庫(kù)的方法
- thinkPHP5實(shí)現(xiàn)數(shù)據(jù)庫(kù)添加內(nèi)容的方法
- tp5(thinkPHP5)框架連接數(shù)據(jù)庫(kù)的方法示例
- thinkPHP5框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)連接,跨數(shù)據(jù)連接查詢操作示例
- tp5.1 框架數(shù)據(jù)庫(kù)常見(jiàn)操作詳解【添加、刪除、更新、查詢】