01: Trigger the timestamp of the parent
As the title indicates, when the child model is updated, the timestamp of the parent model can be triggered. For example Comment
belongs to Post
, sometimes it is useful to update the child model causing the parent model timestamp to be updated. For example, when the Comment
model is updated, you want to automatically trigger an update of the Updated_at
timestamp of the parent Post
model. Eloquent
Make it easy, just add a touch
attribute containing the name of the child model relationship.
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Comment extends Model { /** * 涉及到的所有关联关系。 * * @var array */ protected $touches = ['post']; /** * 获取评论所属的文章。 */ public function post() { return $this->belongsTo('App\Post'); } }
02: Preloading exact columns
When using preloading, you can get the specified columns from the relationship.
$users = App\Book::with('author:id,name')->get();
03: Authenticate the user for a single request
You can use Auth::once()
to authenticate the user for a single request, this method will not use Cookie
Session. This means that this method may be useful for building stateless API.
if (Auth::once($credentials)) { // }
04: Redirect to a controller method with parameters
You can not only use the redirect()
method with user-specific URLs or routes, It can also be used in methods with parameters in the controller.
return redirect()->action('SomeController@method', ['param' => $value]);
05: How to use withDefault()
to avoid errors in relationships
When a relationship is called, a fatal error occurs if it does not exist Errors, such as $post->user->name
, can be avoided using withDefault()
.
/** 获取文章作者 */ public function user() { return $this->belongsTo('App\User')->withDefault(); }
06: In the template, two parallel $loop
variables
are in foreach
of blade
, Even in two loops, you can still get the parent variable by using the $loop
variable.
@foreach ($users as $user) @foreach ($user->posts as $post) @if ($loop->parent->first) This is first iteration of the parent loop. @endif @endforeach @endforeach
07: Modify query results
After executing the Eloqument
query, you can use map()
to modify the rows.
$users = User::where('role_id', 1)->get()->map(function (User $user) { $user->some_column = some_function($user); return $user; });
08: Easily use dd()
Add $test->dd() at the end of
Eloqument
, instead of dd($result)
.
// 优化前 $users = User::where('name', 'Taylor')->get(); dd($users); // 优化后 $users = User::where('name', 'Taylor')->get()->dd();
09: Use hasMany to saveMany.
If there is a hasMany()
relationship and you want to save many subclass objects from the parent class object, you can use saveMany()
to achieve the effect you want.
$post = Post::find(1); $post->comments()->saveMany([ new Comment(['message' => 'First comment']), new Comment(['message' => 'Second comment']), ]);
10: Specifying columns in Model::all()
When you use Eloqument
's Model::all( )
, you can specify the columns to be returned.
$users = User::all(['id', 'name', 'email']);
11: @auth
in
Blade You can use the @auth
directive instead of if
statement to check if the user is authenticated.
Typical method:
@if(auth()->user()) // The user is authenticated. @endif
Short method:
@auth // The user is authenticated. @endauth
12: Preview email without sending
If you use Mailables to send your emails, you can preview them without sending them.
Route::get('/mailable', function () { $invoice = App\Invoice::find(1); return new App\Mail\InvoicePaid($invoice); });
13: Specific check for hasMany
In the hasMany()
relationship of Eloquent
you can filter out Records with n number of sub-records.
// Author -> hasMany(Book::class) $authors = Author::has('books', '>', 5)->get();
14: Restore multiple soft deletions
If the records use soft deletion, then you can restore multiple soft deleted records at one time.
Post::withTrashed()->where('author_id', 1)->restore();
15: Migration column with time zone
The migration file not only has timestamps()
timestamps, but also timestampsTz()
with time zone timestamp.
Schema::create('employees', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->string('email'); $table->timestampsTz(); });
16: Does the view file exist?
Did you know you can also check if a view file exists?
if (view()->exists('custom.page')) { // Load the view }
17: Routing groups in groups
In the routing file, you can create a group for a routing group and specify specific middleware for it.
Route::group(['prefix' => 'account', 'as' => 'account.'], function() { Route::get('login', 'AccountController@login'); Route::get('register', 'AccountController@register'); Route::group(['middleware' => 'auth'], function() { Route::get('edit', 'AccountController@edit'); }); });
18: Date and time methods in Eloquent
whereDay()
, whereMonth()
, whereYear()
, whereDate()
, whereTime()
These methods are all methods for checking dates in Eloquent
.
$products = Product::whereDate('created_at', '2018-01-31')->get(); $products = Product::whereMonth('created_at', '12')->get(); $products = Product::whereDay('created_at', '31')->get(); $products = Product::whereYear('created_at', date('Y'))->get(); $products = Product::whereTime('created_at', '=', '14:13:58')->get();
19: Using orderBy() in the
Eloquent relationship
You can specify # directly in the Eloquent
relationship ##orderBy() .
public function products() { return $this->hasMany(Product::class); } public function productsByName() { return $this->hasMany(Product::class)->orderBy('name'); }20: Unsigned integerFor migrated foreign keys, do not use
integer(), but use
unsignedInteger() or It is
integer()->unsigned(), otherwise a series of errors will occur.
Schema::create('employees', function (Blueprint $table) { $table->unsignedInteger('company_id'); $table->foreign('company_id')->references('id')->on('companies'); });For more Laravel related technical articles, please visit the
Laravel Tutorial column to learn!
The above is the detailed content of Some tips when using Laravel. For more information, please follow other related articles on the PHP Chinese website!

As of October 2023, Laravel's latest version is 10.x. 1.Laravel10.x supports PHP8.1, improving development efficiency. 2.Jetstream improves support for Livewire and Inertia.js, simplifies front-end development. 3.EloquentORM adds full-text search function to improve data processing performance. 4. Pay attention to dependency package compatibility when using it and apply cache optimization performance.

LaravelMigrationsstreamlinedatabasemanagementbyprovidingversioncontrolforyourdatabaseschema.1)Theyallowyoutodefineandsharethestructureofyourdatabase,makingiteasytomanagechangesovertime.2)Migrationscanbecreatedandrunusingsimplecommands,ensuringthateve

Laravel's migration system is a powerful tool for developers to design and manage databases. 1) Ensure that the migration file is named clearly and use verbs to describe the operation. 2) Consider data integrity and performance, such as adding unique constraints to fields. 3) Use transaction processing to ensure database consistency. 4) Create an index at the end of the migration to optimize performance. 5) Maintain the atomicity of migration, and each file contains only one logical operation. Through these practices, efficient and maintainable migration code can be written.

Laravel's latest version is 10.x, released in early 2023. This version brings enhanced EloquentORM functionality and a simplified routing system, improving development efficiency and performance, but it needs to be tested carefully during upgrades to prevent problems.

Laravelsoftdeletesallow"deletion"withoutremovingrecordsfromthedatabase.Toimplement:1)UsetheSoftDeletestraitinyourmodel.2)UsewithTrashed()toincludesoft-deletedrecordsinqueries.3)CreatecustomscopeslikeonlyTrashed()forstreamlinedcode.4)Impleme

In Laravel, restore the soft deleted records using the restore() method, and permanently delete the forceDelete() method. 1) Use withTrashed()->find()->restore() to restore a single record, and use onlyTrashed()->restore() to restore a single record. 2) Permanently delete a single record using withTrashed()->find()->forceDelete(), and multiple records use onlyTrashed()->forceDelete().

You should download and upgrade to the latest Laravel version as it provides enhanced EloquentORM capabilities and new routing features, which can improve application efficiency and security. To upgrade, follow these steps: 1. Back up the current application, 2. Update the composer.json file to the latest version, 3. Run the update command. While some common problems may be encountered, such as discarded functions and package compatibility, these issues can be solved through reference documentation and community support.

YoushouldupdatetothelatestLaravelversionwhenthebenefitsclearlyoutweighthecosts.1)Newfeaturesandimprovementscanenhanceyourapplication.2)Securityupdatesarecrucialifvulnerabilitiesareaddressed.3)Performancegainsmayjustifyanupdateifyourappstruggles.4)Ens


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

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

WebStorm Mac version
Useful JavaScript development tools
