Laravel5.1 框架模型軟刪除操作實(shí)例分析
本文實(shí)例講述了Laravel5.1 框架模型軟刪除操作。分享給大家供大家參考,具體如下:
軟刪除是比較實(shí)用的一種刪除手段,比如說 你有一本賬 有一筆記錄你覺得不對(duì)給刪了 過了幾天發(fā)現(xiàn)不應(yīng)該刪除,這時(shí)候軟刪除的目的就實(shí)現(xiàn)了 你可以找到已經(jīng)被刪除的數(shù)據(jù)進(jìn)行操作 可以是還原也可以是真正的刪除。
1 普通刪除
在軟刪除之前咱先看看普通的刪除方法:
1.1 直接通過主鍵刪除
public function getDelete()
{
Article::destroy(1);
Article::destroy([1,2,3]);
}
1.2 獲取model后刪除
public function getDelete()
{
$article = Article::find(3);
$article->delete();
}
1.3 批量刪除
public function getDelete()
{
// 返回一個(gè)整形 刪除了幾條數(shù)據(jù)
$deleteRows = Article::where('id','>',3)->delete();
dd($deleteRows); // 2
}
2 軟刪除
2.1 準(zhǔn)備工作
如果你要實(shí)現(xiàn)軟刪除 你應(yīng)該提前做3件事情:
- 添加deleted_at 到模型的 $date 屬性中。
- 在模型中使用 Illuminate\Database\Eloquent\SoftDeletes 這個(gè)trait
- 保證你的數(shù)據(jù)表中有deleted_at列 如果沒有就添加這個(gè)列。
首先我們做第一步和第二步:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Article extends Model
{
// 使用SoftDeletes這個(gè)trait
use SoftDeletes;
// 白名單
protected $fillable = ['title', 'body'];
// dates
protected $dates = ['deleted_at'];
}
然后我們生成一個(gè)遷移文件來增加deleted_at列到數(shù)據(jù)表:
class InsertDeleteAtIntroArticles extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::table('articles', function (Blueprint $table) {
$table->softDeletes();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::table('articles', function (Blueprint $table) {
$table->dropSoftDeletes();
});
}
}
2.2 實(shí)現(xiàn)軟刪除
現(xiàn)在我們就可以刪除一條數(shù)據(jù)試試?yán)玻?/p>
public function getDelete()
{
$article = Article::first();
$article->delete();
}
↑ 當(dāng)我們刪了這條數(shù)據(jù)后 在數(shù)據(jù)表中的表示是 deleted_at 不為空 它是一個(gè)時(shí)間值,當(dāng)delete_at不為空時(shí) 證明這條數(shù)據(jù)已經(jīng)被軟刪除了。
2.3 判斷數(shù)據(jù)是否被軟刪除
if ($article->trashed()){
echo '這個(gè)模型已經(jīng)被軟刪除了';
}
2.4 查詢到被軟刪除的數(shù)據(jù)
有一點(diǎn)需要注意,當(dāng)數(shù)據(jù)被軟刪除后 它會(huì)自動(dòng)從查詢數(shù)據(jù)中排除、就是它無法被一般的查詢語句查詢到。當(dāng)我們想要查詢軟刪除數(shù)據(jù)時(shí) 可以使用withTrashed方法
public function getIndex()
{
$article = Article::withTrashed()->first();
if ($article->trashed()){
echo '被軟刪除了'; // 代碼會(huì)執(zhí)行到這一行
}
}
我們還可以使用onlyTrashed,它和withTrashed的區(qū)別是 它只獲得軟刪除的數(shù)據(jù)。
public function getIndex()
{
$articles = Article::onlyTrashed()->where('id','<','10')->get()->toArray();
dd($articles);
}
2.5 恢復(fù)被軟刪除的數(shù)據(jù)
public function getIndex()
{
$article = Article::withTrashed()->find(6);
$article->restore();
}
2.6 永久刪除數(shù)據(jù)
public function getIndex()
{
$article = Article::withTrashed()->find(6);
$article->forceDelete();
}
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
詳解Grunt插件之LiveReload實(shí)現(xiàn)頁面自動(dòng)刷新(兩種方案)
這篇文章主要通過兩種方案詳解Grunt插件之LiveReload實(shí)現(xiàn)頁面自動(dòng)刷新,需要的朋友可以參考下2015-07-07
PHP實(shí)現(xiàn)四種基礎(chǔ)排序算法的運(yùn)行時(shí)間比較(推薦)
本文給大家介紹PHP實(shí)現(xiàn)四種基礎(chǔ)排序算法的運(yùn)行時(shí)間比較,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看下吧2016-08-08
PHP中幾個(gè)可以提高運(yùn)行效率的代碼寫法、技巧分享
這篇文章主要介紹了PHP中幾個(gè)可以提高運(yùn)行效率的代碼寫法、技巧分享,本文分享的5個(gè)方法都是在細(xì)微之處有所不同,一定要認(rèn)真仔細(xì)的去看代碼哦,需要的朋友可以參考下2014-08-08

