Lädt...


🔧 Laravel Artisan Command: Truncate Table and All Related Tables


Nachrichtenbereich: 🔧 Programmierung
🔗 Quelle: dev.to

Managing database tables often involves performing operations like truncating tables, especially during development or testing phases. Truncating a table means deleting all its records while keeping its structure intact. However, when dealing with tables having foreign key relationships, truncating them can become cumbersome.

This blog post introduces a custom Laravel Artisan command that efficiently handles truncating a specified table and all its related tables. The command is useful when you need to reset the database state by clearing out all records, ensuring no foreign key constraints are violated.

The Command

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Str;

class TruncateTableAndAllRelationshipsTableCommand extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'table:truncate-all {table}';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Truncates the specified table and all dependent tables with foreign key references.';

    /**
     * Execute the console command.
     */

    public function handle()
    {
        $table = $this->argument('table');

        $this->info(PHP_EOL."Truncating $table and the following related tables:");

        // Disable foreign key checks
        DB::statement('SET FOREIGN_KEY_CHECKS=0;');

        // Get related tables via foreign keys
        $relatedTables = $this->getReferencingTablesFrom($table);

        if (count($relatedTables)) {
            // Truncate the related tables
            foreach ($relatedTables as $relatedTable) {
                if ($relatedTable != $table) {
                    DB::table($relatedTable)->truncate();
                    $this->info("Table {$relatedTable} truncated.");
                }
            }
        }

        // Truncate the specified table
        DB::table($table)->truncate();
        $this->info("Table {$table} truncated.");

        // Re-enable foreign key checks
        DB::statement('SET FOREIGN_KEY_CHECKS=1;');

        $this->info(PHP_EOL."Done!");
        return 0;
    }

    protected function getReferencingTablesFrom(string $table)
    {
        $referencingTables = [];

        // Get all tables in the database
        $tables = Schema::getConnection()->getDoctrineSchemaManager()->listTableNames();
        $refTable = Str::singular($table);

        foreach ($tables as $table) {
            // Check if the table has a referencing column
            if (Schema::hasColumn($table, $refTable.'_uuid')) {
                // Assume it is a foreign key referencing the specified table
                $referencingTables[] = $table;
            }
        }

        return $referencingTables;
    }
}

Avoiding Headache

This command is useful if the dependent table is referencing only a foreign key of the specified table otherwise you need to re-strategize and tweak the codes to avoid truncating other tables that other dependents.

Great, now that we're ready to proceed, to see the backbone of the command.

Understanding the Command

The provided code defines a console command named TruncateTableAndAllRelationshipsTableCommand. This command takes a table name as an argument, finds all related tables through foreign key references, and truncates both the specified table and its related tables. Let’s break down the key components of this command.

Handling the Command Execution

public function handle()
{
    $table = $this->argument('table');

    $this->info(PHP_EOL."Truncating $table and the following related tables:");

    // Disable foreign key checks
    DB::statement('SET FOREIGN_KEY_CHECKS=0;');

    // Get related tables via foreign keys
    $relatedTables = $this->getReferencingTablesFrom($table);

    if (count($relatedTables)) {
        // Truncate the related tables
        foreach ($relatedTables as $relatedTable) {
            if ($relatedTable != $table) {
                DB::table($relatedTable)->truncate();
                $this->info("Table {$relatedTable} truncated.");
            }
        }
    }

    // Truncate the specified table
    DB::table($table)->truncate();
    $this->info("Table {$table} truncated.");

    // Re-enable foreign key checks
    DB::statement('SET FOREIGN_KEY_CHECKS=1;');

    $this->info(PHP_EOL."Done!");
    return 0;
}

The handle method is the entry point of the command execution. It performs the following steps:

  1. Retrieve the Table Name: Gets the table name from the command argument.
  2. Disable Foreign Key Checks: Temporarily disables foreign key checks to avoid constraint violations while truncating.
  3. Get Related Tables: Calls getReferencingTablesFrom method to find all tables referencing the specified table.
  4. Truncate Related Tables: Iterates over the related tables and truncates them.
  5. Truncate Specified Table: Truncates the specified table.
  6. Re-enable Foreign Key Checks: Re-enables foreign key checks after truncation.

Finding Related Tables

protected function getReferencingTablesFrom(string $table)
{
    $referencingTables = [];

    // Get all tables in the database
    $tables = Schema::getConnection()->getDoctrineSchemaManager()->listTableNames();
    $refTable = Str::singular($table);

    foreach ($tables as $table) {
        // Check if the table has a referencing column
        if (Schema::hasColumn($table, $refTable.'_uuid')) {
            // Assume it is a foreign key referencing the specified table
            $referencingTables[] = $table;
        }
    }

    return $referencingTables;
}

The getReferencingTablesFrom method inspects all tables in the database to find those containing a column that likely references the specified table. It assumes that a column named {table}_uuid or you can name it {table}_id if you are not using uuid for indicating a foreign key relationship.

Example Usage

Let’s consider an example where you have the following tables:

  • users
  • posts (contains a user_uuid column referencing users)
  • comments (contains a post_uuid column referencing posts)

To truncate the users table and all related tables, you can run the following command:

php artisan table:truncate-all users

This command will:

  1. Disable foreign key checks.
  2. Identify posts as a table related to users and comments as a table related to posts.
  3. Truncate comments, posts, and users.
  4. Re-enable foreign key checks.

Possible Scenarios

Testing and Development

During testing or development, you might need to reset your database state frequently. This command ensures all related data is cleared without violating foreign key constraints, making it easier to reset the database.

Data Migration

When performing data migration or restructuring, you may need to truncate tables and repopulate them with new data. This command helps in clearing the existing data while maintaining the integrity of foreign key relationships.

Bulk Data Deletion

In scenarios where you need to delete a large volume of data across multiple related tables, this command provides a clean and efficient way to achieve that.

Conclusion

The TruncateTableAndAllRelationshipsTableCommand is a powerful tool for managing database tables with foreign key relationships in Laravel. It simplifies the process of truncating tables and ensures data integrity by handling related tables automatically. This command is particularly useful in development, testing, and data migration scenarios. Implementing such a command can significantly streamline database management tasks, making your workflow more efficient and error-free.

...

🔧 Laravel Artisan Command: Truncate Table and All Related Tables


📈 112.47 Punkte
🔧 Programmierung

🎥 Delete unpaid orders using custom Artisan command | Laravel E-commerce project


📈 40.04 Punkte
🎥 Video | Youtube

🔧 Artisan – The Command-Line Interface Included with Laravel


📈 40.04 Punkte
🔧 Programmierung

🔧 Laravel, artisan serve, and HTTPS


📈 36.17 Punkte
🔧 Programmierung

🔧 Mastering Laravel Artisan Commands: Optimize, Tinker, and More


📈 36.17 Punkte
🔧 Programmierung

🔧 Boost Your Laravel Development: 5 Lesser-Known Artisan Commands


📈 34.5 Punkte
🔧 Programmierung

🔧 Laravel — PHP Artisan Serve Failed


📈 34.5 Punkte
🔧 Programmierung

🔧 Laravel Task Scheduling – Scheduling Artisan Commands


📈 34.5 Punkte
🔧 Programmierung

🔧 HTML Tables: how to create and style tables with HTML


📈 31.95 Punkte
🔧 Programmierung

📰 Microsoft Excel Can Now Turn Pictures of Tables Into Actual, Editable Tables


📈 30.29 Punkte
📰 IT Security Nachrichten

🕵️ Medium CVE-2017-18597: Jtrt responsive tables project Jtrt responsive tables


📈 30.29 Punkte
🕵️ Sicherheitslücken

🕵️ Low CVE-2015-9401: Websimon-tables project Websimon-tables


📈 30.29 Punkte
🕵️ Sicherheitslücken

📰 Storytelling with Tables Part 1: Tables with Plotly


📈 30.29 Punkte
🔧 AI Nachrichten

🔧 How to Apply Sorting on Tables in HTML Using JavaScript: Sortable Paginated Tables


📈 30.29 Punkte
🔧 Programmierung

🔧 Using Mapping Tables to Merge Data with Auto-Number Keys Referenced by Other Tables


📈 30.29 Punkte
🔧 Programmierung

🐧 How to Use Breakpoints and Media Queries with Truncate, Text-Ellipsis and Text-Clip


📈 30.06 Punkte
🐧 Linux Tipps

🐧 [$] Long-term get_user_pages() and truncate(): solved at last?


📈 28.4 Punkte
🐧 Linux Tipps

🐧 DELETE FROM and TRUNCATE With MySQL


📈 28.4 Punkte
🐧 Linux Tipps

🔧 How to Truncate Text with CSS and JavaScript


📈 28.4 Punkte
🔧 Programmierung

🔧 Differences Between DROP, DELETE and TRUNCATE in SQL


📈 28.4 Punkte
🔧 Programmierung

🔧 PMM, Federated Tables, Table Stats, and Lots of Connections!


📈 28.15 Punkte
🔧 Programmierung

🔧 Purging Data When the Table Is Big and Has Children Tables


📈 28.15 Punkte
🔧 Programmierung

🔧 Getting start with Tables using Next.js, Tanstack Table and Typescript


📈 28.15 Punkte
🔧 Programmierung

🔧 Add Missing Sequence Numbers to One Table according to The Other and Combine Two Tables #eg18


📈 28.15 Punkte
🔧 Programmierung

🕵️ Linux Kernel up to 2.6.14 mm/truncate.c invalidate_inode_pages2_range denial of service


📈 26.73 Punkte
🕵️ Sicherheitslücken

🕵️ Schneider Electric Modicon M340 SNMP Server SNMP Packet Truncate denial of service


📈 26.73 Punkte
🕵️ Sicherheitslücken

matomo