


Erfahren Sie in einem Artikel mehr über das Löschen von Laravel-Modellen und das weiche Löschen
1. Modell löschen
1.1 Verwenden Sie „Löschen“, um ein Modell zu löschen
Das Löschen eines Modells ist sehr einfach. Rufen Sie zuerst die zu löschende Modellinstanz ab und rufen Sie dann die Löschmethode auf:
$post = Post::find(5); if($post->delete()){ echo '删除文章成功!'; }else{ echo '删除文章失败!'; }
Die Methode gibt wahr oder falsch zurück.
1.2 Verwenden Sie destroy, um ein Modell zu löschen
Wenn die zu löschende Modell-ID bekannt ist, können Sie sie natürlich auch mit der einfacheren Methode destroy direkt löschen:
$deleted = Post::destroy(5);
Sie können auch mehrere Modelle löschen, indem Sie mehrere Modell-IDs gleichzeitig übergeben:
$deleted = Post::destroy([1,2,3,4,5]);
Rufen Sie die Methode destroy auf, um die Anzahl der gelöschten Datensätze zurückzugeben.
1.3 Löschen eines Modells mit dem Abfrage-Builder
Da bereits erwähnt wurde, dass das Eloquent-Modell selbst ein Abfrage-Builder ist, können Sie das Modell auch löschen Verwenden des Abfrage-Builder-Stils. Wenn wir beispielsweise alle Artikel mit 0 Ansichten löschen möchten, können wir die folgende Methode verwenden:
$deleted = Models\Post::where('views', 0)->delete();
Das zurückgegebene Ergebnis ist die Anzahl der gelöschten Artikel.
2. Soft-Deletion-Implementierung
Die oben genannten Löschmethoden löschen auch die Datentabellendatensätze aus der Datenbank unterstützt weiches Löschen.
Das sogenannte Soft-Deletion bedeutet, dass die Datentabellendatensätze nicht tatsächlich aus der Datenbank gelöscht werden, sondern der Identifikationsstatus der Tabellendatensätze als Soft-Deletion markiert wird, sodass er bei der Abfrage gefiltert werden kann dass die entsprechenden Tabellendatensätze anscheinend „gelöscht“ wurden. Laravel verwendet ein Datumsfeld als Identifikationsstatus. Dieses Datumsfeld kann angepasst werden. Wenn das entsprechende Modell vorläufig gelöscht ist, ist der Wert des Feldes delete_at die Löschzeit.
Damit das Eloquent-Modell das sanfte Löschen unterstützt, müssen einige Einstellungen vorgenommen werden. Verwenden Sie zunächst SoftDeletestrait in der Modellklasse. Weitere Informationen finden Sie im Quellcode IlluminateDatabaseEloquentSoftDeletes. Außerdem müssen Sie das Attributarray $date festlegen:
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes; class Post extends Model { use SoftDeletes; //设置表名 public $table = 'posts'; //设置主键 public $primaryKey = 'id'; //设置日期时间格式 public $dateFormat = 'U'; protected $guarded = ['id','views','user_id','updated_at','created_at']; protected $dates = ['delete_at']; }
Fügen Sie dann die Spalte „deleded_at“ zu den entsprechenden Datenbankbeiträgen hinzu. Dazu führen wir zunächst den Artisan-Befehl aus:
php artisan make:migration alter_posts_deleted_at --table=posts
und bearbeiten dann die generierte PHP-Datei wie folgt:
<?php use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class AlterPostsDeletedAt extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::table('posts', function (Blueprint $table) { $table->softDeletes(); }); } ...//其它方法 }
und führen Sie dann Folgendes aus:
php artisan migrate
Auf diese Weise wird in den Beiträgen die Spalte „deled_at“ angezeigt. Als nächstes schreiben wir den Testcode in den Controller:
$post = Post::find(6); $post->delete(); if($post->trashed()){ echo '软删除成功!'; dd($post); }else{ echo '软删除失败!'; }
Was ist, wenn wir vorläufig gelöschte Datensätze in die Abfrageergebnisse einschließen möchten? Sie können die withTrashed-Methode für das SoftDeletes-Merkmal verwenden:
$posts = Post::withTrashed()->get(); dd($posts);
Manchmal möchten wir nur das vorläufig gelöschte Modell anzeigen. Es gibt auch einen Trick über die onlyTrashed-Methode für SoftDeletes:
$posts = Post::onlyTrashed()->get(); dd($posts);
Soft-Deletion-Wiederherstellung
Manchmal müssen wir ein vorläufig gelöschtes Modell wiederherstellen. Sie können die von SoftDeletes bereitgestellte Wiederherstellungsmethode verwenden:
Ein einzelnes wiederherstellen. Mit dem Modell stimmt etwas nicht
$post = Post::find(6); $post->restore();
Das Modell mit der ID 6 wurde vorläufig gelöscht.
sollte
$post = Post::withTrashed()->find(6); $post->restore();
Mehrere Modelle wiederherstellen
Post::withTrashed()->where('id','>',1)->restore();
Alle Modelle wiederherstellen
Post::withTrashed()->restore();
Zugeordnetes Abfragemodell wiederherstellen
$post = Post::find(6); $post->history()->restore();
Erzwungenes Löschen
Wenn das Modell mit weichem Löschen konfiguriert ist, wir aber wirklich die dem Modell entsprechenden Datenbanktabellendatensätze löschen möchten , wir können die von SoftDeletes bereitgestellte forceDelete-Methode verwenden:
$post = Post::find(6); $post->forceDelete();
PHP Chinesische Website, eine große Anzahl kostenloser Laravel-Einführungs-Tutorials, willkommen zum Online-Lernen!
Dieser Artikel wurde reproduziert von: https://blog.csdn.net/weixin_38112233/article/details/78574007
Das obige ist der detaillierte Inhalt vonErfahren Sie in einem Artikel mehr über das Löschen von Laravel-Modellen und das weiche Löschen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Leitfaden zum Testen von PHP-Einheiten und -Integrationen Unit-Tests: Konzentrieren Sie sich auf eine einzelne Code- oder Funktionseinheit und verwenden Sie PHPUnit, um Testfallklassen zur Überprüfung zu erstellen. Integrationstests: Achten Sie darauf, wie mehrere Codeeinheiten zusammenarbeiten, und verwenden Sie die Methoden setUp() und TearDown() von PHPUnit, um die Testumgebung einzurichten und zu bereinigen. Praktischer Fall: Verwenden Sie PHPUnit, um Unit- und Integrationstests in Laravel-Anwendungen durchzuführen, einschließlich der Erstellung von Datenbanken, dem Starten von Servern und dem Schreiben von Testcode.

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.
