Come gestire la relazione uno a uno in un modello dati con Laravel Eloquent ORM

Come gestire la relazione uno a uno in un modello dati con Laravel Eloquent ORM
Nella modellazione dei dati Entity Relationship, esiste una relazione uno-a-uno quando un record in una tabella è associato esattamente a un record in un'altra tabella e viceversa.

Tempo di lettura stimato: 3 minuti



Relazione Uno a Uno

Una relazione uno-a-uno non è una proprietà dei dati stessi, ma della relazione tra le tabelle. Garantisce che ogni riga di una tabella corrisponda al massimo a una riga di un'altra tabella.



Consideriamo alcuni esempi di relazione uno a uno, nella vita reale:



Paese - Capitale: Ogni paese ha esattamente una capitale. Ogni capitale è la capitale esattamente di un paese.



Persona - Impronte digitali: Ogni persona ha un set unico di impronte digitali. Ogni serie di impronte digitali identifica esattamente una persona.



E-mail - Account utente: Per molti siti Web, un indirizzo e-mail è associato esattamente a un account utente. Ogni account utente è identificato dal suo indirizzo email.



Laravel Eloquent ORM Relazione Uno a Uno

Laravel Eloquent fornisce metodi completi per gestire le relazioni tra le tabelle del database. In questo articolo vedremo la relazione uno a uno, e come impostarla.



Scenario: Users e Phones

Ipotizziamo di avere due tabella: users e phones. Vogliamo introdurre un vincolo, cioè ogni utente deve avere un numero di telefono "univoco", e che ogni numero di telefono può essere associato a un solo utente.



Database: migrations

Creiamo le migrations per le tabelle users e phones. Ecco come è possibile definire lo schema per queste tabelle:



// Create migration for 'users' table

Schema::create('users', function (Blueprint $table) {

$table->increments('id');

$table->string('name');

$table->string('email')->unique();

$table->timestamps();

});



// Create migration for 'phones' table with foreign key

Schema::create('phones', function (Blueprint $table) {

$table->increments('id');

$table->integer('user_id')->unsigned();

$table->string('phone_no');

$table->timestamps();



// Define foreign key relationship

$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

});

Nella tabella phones, impostiamo user_id come chiave esterna che fa riferimento alla colonna id nella tabella degli users. Se un utente viene eliminato, verrà eliminato anche il record telefonico associato (onDelete('cascade')).



Impostazione del modello

Nell'ipotesi di avere due model: User e Phone, vediamo come impostare le relazioni con Laravel Eloquent.



Definiamo le relazioni in questi modelli:



// User model

class User extends Authenticatable {

// Other attributes and methods...



/**

* Get the mobile number associated with the user.

*/

public function mobile() {

return $this->hasOne(Phone::class);

// Alternatively, you can specify the full model path: 'AppPhone'

}

}



// Phone model (app/Phone.php)

class Phone extends Model {

/**

* Get the user that owns the phone.

*/

public function user() {

return $this->belongsTo(User::class);

}

}

Il metodo hasOne nel modello User stabilisce la relazione uno-a-uno con il modello Phone.



Il metodo belongsTo nel modello Phone definisce la relazione inversa, permettendoci di accedere all'utente associato a un telefono.



Esempio di utilizzo

Inserire

Per inserire un record in Users e in Phones:



// Create a user and associate a phone

$user = User::create();

$user->mobile()->create();

Leggere

Per leggere il numero di telefono (Phone) di un utente (User):



// Get user's phone number

$phone = $user->mobile;

Aggiornare

// Update user's phone number

$phone->update();

Cancellare

// Delete user (phone record will be deleted automatically)

$user->delete();

Sfruttando le relazioni uno a uno in Laravel Eloquent, possiamo organizzare in modo efficiente i dati tra le tabelle correlate. Una buona conoscenza di queste relazioni, ci consente di creare applicazioni robuste ed efficienti.



Letture Correlate

- Cos'è Laravel Eloquent, come si usa, tutorial con esempi

- Business Model Innovation, quali sono le potenzialità del modello

- Snapchat: ufficiale il gioco in realtà aumentata Ghost Phone

- Come creare un report di progetto con Microsoft Project

- Perchè Fire phone di Amazon è stato un fallimento. Arriva Ice

Ercole Palmeri


Ercole Palmeri
#laravel #Tutorial
https://bloginnovazione.it/laravel-relazione/47208/

Commenti

Post popolari in questo blog

Come impostare i giorni lavorativi in ​​Microsoft Project: calendario di progetto