


Laravel association model problems caused by name consistency laravel video tutorial thinkphp php laravel
1. Define the association model
In Laravel, we can complete the association query by defining the following Model.
class MyPost extends Eloquent { public function myPostInfo () { return $this->hasOne('MyPostInfo'); } } class MyPostInfo extends Eloquent {}
2. Use the association model
HeremyPostInfo()
uses Camel naming rules, but we can use Snake rules when reading a certain PostInfo. The following code is feasible:
$post = MyPost::find(1); $post_info = $post->myPostInfo; // example 1 $post_info = $post->my_post_info; // example 2
Laravel allows the above two methods, but does not reasonably handle the conflict caused by using the two naming methods.
3. Cache invalidation
If we use the above two examples at the same time, one of the caches will be invalidated. In the relationships variable of the Model, the related Model that has been read is cached, but when we read it with a name with different rules, the previous cache will be invalidated. For example
$post_info = $post->myPostInfo; // $post->relations = [‘myPostInfo’ => ..]; $post_info = $post->my_post_info; // $post->relations = [‘myPostInfo’ => …, ‘my_post_info’ => …];
So if you don’t want the cache to expire, you have to use only one naming method in the project to read the relational model. Laravel recommends Camel Case.
4. The toArray() method is invalid
If both are used at the same time, another problem is that Model::toArray()
is invalid. Because the toArray()
method first looks for the association model named Snake Case in relations
, and if not, then looks at the Camel Case.
So if you use the toArray()
method to convert the Model, do not use both at the same time.
5. Easy-to-make mistakes
The most easy-to-make code is this:
MyPost::with(‘myPostInfo’)->get();
When using With to eagerLoad to associate the model, you must use the key with the same name as the definition method to read, so how to read it like this It can only be the key of Camel Case. In other places, you can only use
$my_post->myPostInfo;
to ensure there are no problems.
The above introduces the problems caused by name consistency in Laravel's association model, including laravel content. I hope it will be helpful to friends who are interested in PHP tutorials.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

The method of handling Laravel's email failure to send verification code is to use Laravel...

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...

Custom tenant database connection in Laravel multi-tenant extension package stancl/tenancy When building multi-tenant applications using Laravel multi-tenant extension package stancl/tenancy,...

LaravelEloquent Model Retrieval: Easily obtaining database data EloquentORM provides a concise and easy-to-understand way to operate the database. This article will introduce various Eloquent model search techniques in detail to help you obtain data from the database efficiently. 1. Get all records. Use the all() method to get all records in the database table: useApp\Models\Post;$posts=Post::all(); This will return a collection. You can access data using foreach loop or other collection methods: foreach($postsas$post){echo$post->

How to check the validity of Redis connections in Laravel6 projects is a common problem, especially when projects rely on Redis for business processing. The following is...

A problem of duplicate class definition during Laravel database migration occurs. When using the Laravel framework for database migration, developers may encounter "classes have been used...
