Heim PHP-Framework Laravel Datenmigration und -population mit Laravel: Datenbankstruktur flexibel verwalten

Datenmigration und -population mit Laravel: Datenbankstruktur flexibel verwalten

Aug 26, 2023 am 09:28 AM
laravel 数据迁移 数据填充

Datenmigration und -population mit Laravel: Datenbankstruktur flexibel verwalten

Verwenden Sie Laravel für die Datenmigration und -befüllung: Flexible Verwaltung der Datenbankstruktur

Zusammenfassung:
Laravel ist ein sehr beliebtes PHP-Framework, das eine bequeme Möglichkeit zur Verwaltung der Datenbankstruktur, einschließlich Datenmigration und Datenbefüllung, bietet. In diesem Artikel erfahren Sie, wie Sie die Migrations- und Auffüllfunktionen von Laravel nutzen, um Ihre Datenbankstruktur flexibel zu verwalten.

1. Datenmigration
Die Datenmigration ist ein Tool zur Verwaltung von Änderungen in der Datenbankstruktur. Sie können PHP-Code verwenden, um Elemente wie Datenbanktabellen, Spalten, Indizes und Einschränkungen zu definieren und zu ändern.

In Laravel erfolgt die Datenmigration mit dem Kommandozeilentool Artisan. Erstellen wir zunächst eine neue Datenmigrationsdatei:

php artisan make:migration create_users_table
Nach dem Login kopieren

Dadurch wird eine neue Migrationsdatei im Verzeichnis database/migrations erstellt. Öffnen Sie die Datei und Sie sehen eine up-Methode und eine down-Methode. Mit der Methode up werden die durchzuführenden Änderungsvorgänge definiert und mit der Methode down können diese Vorgänge rückgängig gemacht werden. database/migrations目录下创建一个新的迁移文件。打开该文件,您可以看到一个up方法和一个down方法。up方法用于定义要执行的修改操作,down方法用于撤销这些操作。

例如,我们可以在up方法中创建一个名为users的表,并添加一个自增的id列和一个name列:

use IlluminateDatabaseMigrationsMigration;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateSupportFacadesSchema;

class CreateUsersTable extends Migration
{
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->id();
            $table->string('name');
            $table->timestamps();
        });
    }
    
    public function down()
    {
        Schema::dropIfExists('users');
    }
}
Nach dem Login kopieren

然后,我们可以使用以下命令来执行迁移:

php artisan migrate
Nach dem Login kopieren

该命令将读取所有未应用的迁移,并依次执行它们。如果您想撤销迁移,可以使用以下命令:

php artisan migrate:rollback
Nach dem Login kopieren

这样可以撤销最近的一次迁移。如果您想撤销所有迁移,可以使用以下命令:

php artisan migrate:reset
Nach dem Login kopieren

二、数据填充
数据填充是用于向数据库中添加预定义数据的工具。它允许您使用PHP代码来生成和填充数据库表的数据。

在Laravel中,数据填充使用命令行工具Artisan来执行。首先,让我们创建一个新的数据填充文件:

php artisan make:seeder UsersTableSeeder
Nach dem Login kopieren

这将在database/seeds目录下创建一个新的填充文件。打开该文件,您可以看到一个run方法。在该方法中,您可以使用Eloquent模型来创建和保存数据库记录。

例如,我们可以在run方法中创建一个名为users的表,并添加一些示例用户:

use IlluminateDatabaseSeeder;
use AppModelsUser;

class UsersTableSeeder extends Seeder
{
    public function run()
    {
        User::create([
            'name' => 'John Doe',
            'email' => 'john@example.com',
            'password' => bcrypt('password')
        ]);
        
        User::create([
            'name' => 'Jane Doe',
            'email' => 'jane@example.com',
            'password' => bcrypt('password')
        ]);
    }
}
Nach dem Login kopieren

然后,我们可以使用以下命令来执行填充:

php artisan db:seed --class=UsersTableSeeder
Nach dem Login kopieren

该命令将执行指定填充类中的run方法,并将示例用户添加到users

Zum Beispiel können wir in der Methode up eine Tabelle mit dem Namen users erstellen und eine automatisch inkrementierende Spalte id und einen name-Spalte:

php artisan db:seed
Nach dem Login kopieren
Dann können wir den folgenden Befehl verwenden, um Migrationen auszuführen:

rrreee

Dieser Befehl liest alle nicht angewendeten Migrationen und führt sie nacheinander aus. Wenn Sie eine Migration rückgängig machen möchten, können Sie den folgenden Befehl verwenden:

rrreee
Dadurch wird die letzte Migration rückgängig gemacht. Wenn Sie alle Migrationen rückgängig machen möchten, können Sie den folgenden Befehl verwenden:

rrreee

2. Datenbefüllung

Datenbefüllung ist ein Tool, mit dem vordefinierte Daten zur Datenbank hinzugefügt werden. Es ermöglicht Ihnen, PHP-Code zum Generieren und Auffüllen von Daten für Datenbanktabellen zu verwenden. 🎜🎜In Laravel erfolgt die Datenbefüllung mit dem Befehlszeilentool Artisan. Erstellen wir zunächst eine neue Daten-Seed-Datei: 🎜rrreee🎜Dadurch wird eine neue Seed-Datei im Verzeichnis database/seeds erstellt. Öffnen Sie die Datei und Sie können eine run-Methode sehen. Bei dieser Methode verwenden Sie Eloquent-Modelle, um Datenbankeinträge zu erstellen und zu speichern. 🎜🎜Zum Beispiel können wir in der Methode run eine Tabelle mit dem Namen users erstellen und einige Beispielbenutzer hinzufügen: 🎜rrreee🎜 Dann können wir den folgenden Befehl verwenden, um Population auszuführen : 🎜rrreee🎜Dieser Befehl führt die Methode run in der angegebenen Populationsklasse aus und fügt den Beispielbenutzer zur Tabelle users hinzu. 🎜🎜Wenn Sie Daten stapelweise füllen möchten, können Sie mehrere Füllklassen erstellen und den folgenden Befehl verwenden, um alle Füllvorgänge durchzuführen: 🎜rrreee🎜Dieser Befehl führt alle Füllvorgänge in alphabetischer Reihenfolge nach den Dateinamen der Füllklassen durch. 🎜🎜Zusammenfassung: 🎜Mit den Datenmigrations- und Füllfunktionen von Laravel können Sie die Datenbankstruktur flexibel verwalten und Daten füllen. Die Datenmigration kann Ihnen bei der Versionskontrolle und der Verfolgung von Datenbankstrukturen helfen, während die Datenpopulation Ihnen bei der Generierung von Demo- oder Initialisierungsdaten helfen kann. 🎜🎜Ob es darum geht, die Datenbanktabellenstruktur in der Entwicklungsumgebung zu ändern oder Daten in der Produktionsumgebung zu initialisieren, die Datenmigrations- und Füllfunktionen von Laravel bieten einfache und leistungsstarke Tools zur Verwaltung und Wartung der Datenbank. 🎜

Das obige ist der detaillierte Inhalt vonDatenmigration und -population mit Laravel: Datenbankstruktur flexibel verwalten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP vs. Flutter: Die beste Wahl für die mobile Entwicklung PHP vs. Flutter: Die beste Wahl für die mobile Entwicklung May 06, 2024 pm 10:45 PM

PHP und Flutter sind beliebte Technologien für die mobile Entwicklung. Flutter zeichnet sich durch plattformübergreifende Funktionen, Leistung und Benutzeroberfläche aus und eignet sich für Anwendungen, die eine hohe Leistung, plattformübergreifende und benutzerdefinierte Benutzeroberfläche erfordern. PHP eignet sich für serverseitige Anwendungen mit geringerer Leistung und nicht plattformübergreifend.

Wie verwende ich objektrelationales Mapping (ORM) in PHP, um Datenbankoperationen zu vereinfachen? Wie verwende ich objektrelationales Mapping (ORM) in PHP, um Datenbankoperationen zu vereinfachen? May 07, 2024 am 08:39 AM

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.

Analyse der Vor- und Nachteile von PHP-Unit-Test-Tools Analyse der Vor- und Nachteile von PHP-Unit-Test-Tools May 06, 2024 pm 10:51 PM

Analyse des PHP-Unit-Test-Tools: PHPUnit: Geeignet für große Projekte, bietet umfassende Funktionalität und ist einfach zu installieren, kann jedoch ausführlich und langsam sein. PHPUnitWrapper: geeignet für kleine Projekte, einfach zu verwenden, optimiert für Lumen/Laravel, verfügt jedoch über eingeschränkte Funktionalität, bietet keine Code-Coverage-Analyse und hat begrenzte Community-Unterstützung.

Laravel – Handwerkerbefehle Laravel – Handwerkerbefehle Aug 27, 2024 am 10:51 AM

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?

Vergleich der neuesten Versionen von Laravel und CodeIgniter Vergleich der neuesten Versionen von Laravel und CodeIgniter Jun 05, 2024 pm 05:29 PM

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.

Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Jun 01, 2024 pm 01:34 PM

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

PHP-Code-Unit-Tests und Integrationstests PHP-Code-Unit-Tests und Integrationstests May 07, 2024 am 08:00 AM

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.

Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Jun 04, 2024 am 09:09 AM

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.

See all articles