Home  >  Article  >  Backend Development  >  [Resolved] Integrity constraint violation – Fast tips

[Resolved] Integrity constraint violation – Fast tips

WBOY
WBOYOriginal
2024-08-17 22:50:091003browse

If you are dealing with the error: "Integrity constraint violation: Cannot add or update a child row: a foreign key constraint fails", you are in the right article.

Usually you encounter this error when you add a new column to a table and declare it as a Foreign Key.

In a SQL database, a foreign key is a field in a table used to establish a link between the data in another table. Consider the customers table below.

CREATE TABLE customers (
    id INT PRIMARY KEY,
    name VARCHAR(255),
    email VARCHAR(255)
);

Now you want to link your customers to a group. First you should add the new column to the customers table that contains the reference to the groups table:

# Create the new column "group_id"
ALTER TABLE customers
ADD COLUMN group_id INT NOT NULL;

Than you can add the foreign key constraint to activate the relation to the groups table:

# Add the FK constraints
ALTER TABLE customers
ADD CONSTRAINT fk_group_id
FOREIGN KEY (group_id)
REFERENCES customers(id);

When you run this alter operation on the customers table the database will verify that the ID in the group_id field exists in the groups table.

During this check the database will raise the "Integrity violation error" because the group_id column is still empty, so it doesn't contain any valid references in the groups table. So the SQL engine fails trying to apply the foreign key constraint. It's because an empty value isn't a valid foreign key to the groups table.

How to solve the Integrity violation error

The most simple action is to declare the new column as nullable.

You can remove the "NOT NULL" instruction from the alter query to allow the group_id column to contain null values.

This simple change will resolve the issue in the first place, because now the foreign key can be null too. You can run the data migration to eventually fill the new group_id column in the customers table, and plan a new release to reintroduce the "NOT NULL" constraint.

If in your application a Customer can’t exist without a specific Group, you should remember that having the group_id nullable, your database is not aware of this constraint.

If you make a mistake during entity creation in your application, the database will not alert you.

Data migration

Another solution is to add a data migration job between the alter query for adding the new column and the one for adding the foreign key.

Once you have the new group_id column in the customers table you can run a script to fill this column for existing rows with a valid ID from the groups table.

This is an example of query to perform this task:

UPDATE customers, groups
SET customers.group_id = groups.id
Where customers.user_id = groups.user_id;

Using Laravel Migrations

In modern applications all of these tasks are performed using the migration tool. It is usually available in most common application development frameworks.

In the example below I'll show you how to deal with the Integrity constraint violation issue using Laravel migrations.

Create the migration:

php artisan make:migration add_goup_id_fk_to_customers –table=customers

You can break the migration in two parts as shown below:

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;

return new class extends Migration
{
    /**
     * Run the migrations.
     */
    public function up(): void
    {
        Schema::create('customers', function (Blueprint $table) {
            $table->unsignedBigInteger('group_id')->nullable();
        });

        // Insert default data into the new column
        DB::raw('UPDATE customers, groups
            SET customers.group_id = groups.id
            WHERE customers.user_id = groups.user_id');

        Schema::table('customers', function (Blueprint $table) {
            // Add the FK constraint
            $table->foreign('group_id')->references('id')->on(groups)->onDelete('cascade');

            // Remove the nullable condition eventually;
            $table->unsignedBigInteger('group_id')->change();
        });



    }

    /**
     * Reverse the migrations.
     */
    public function down(): void
    {
        Schema::table('customers', function (Blueprint $table) {
            $table->dropForeign('group_id');
            $table->dropColumn('group_id');
        });
    }
};

If you are interested in improving database performance you can take a look at the article below about "Smart Database Queries":
https://inspector.dev/how-to-accelerate-application-performance-with-smart-sql-queries/

New To Inspector? Monitor your application for free

Inspector is a Code Execution Monitoring tool specifically designed for software developers. You don't need to install anything at the server level, just install the composer package and you are ready to go.

Unlike other complex, all-in-one platforms, Inspector is super easy, and PHP friendly. You can try our Laravel or Symfony package.

If you are looking for effective automation, deep insights, and the ability to forward alerts and notifications into your messaging environment try Inspector for free. Register your account.

Or learn more on the website: https://inspector.dev

[Resolved] Integrity constraint violation – Fast tips

The above is the detailed content of [Resolved] Integrity constraint violation – Fast tips. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn