Làm cách nào để tạo mô hình và di chuyển trong lệnh Laravel?

Trong đoạn mã ngắn này, bạn sẽ tìm hiểu cách tạo Mô hình, Di chuyển và Trình điều khiển bằng một lệnh nghệ nhân duy nhất. Cách để đạt được điều này là chuyển một lá cờ cho "make. mô hình" lệnh

php artisan make:model -mc Post

Lệnh trên sẽ tạo mô hình cũng như "di chuyển [m]" và "bộ điều khiển [c]" cho tài nguyên "Đăng"

Cờ có sẵn để tạo mô hình trong laravel


Các lệnh có sẵn để tạo mô hình trong Laravel có sẵn bên dưới.
-c, --controller Tạo bộ điều khiển mới cho mô hình

-f, --factory Tạo một nhà máy mới cho mô hình

--force Tạo lớp ngay cả khi mô hình đã tồn tại

-m, --migration Tạo tệp di chuyển mới cho mô hình

-s, --seed Tạo tệp seeder mới cho mô hình

-p, --pivot Cho biết liệu mô hình được tạo có phải là mô hình bảng trung gian tùy chỉnh hay không

-r, --resource Cho biết liệu bộ điều khiển được tạo có phải là bộ điều khiển tài nguyên hay không
Nếu bạn muốn tạo tất cả thì hãy chỉ định cờ "--all" khi chạy .

php artisan make:model Post -all

Để biết chi tiết về loại cờ bạn có thể chuyển vào, bạn có thể chạy lệnh với cờ "-help" như bên dưới

Để thực hiện bất kỳ tác vụ nào, chúng tôi cần tạo một tệp di chuyển tương tự như những gì chúng tôi đã tạo trong khi tạo di chuyển

sự thay đổi duy nhất sẽ có trong tên di chuyển, luôn cố gắng viết tên di chuyển mang tính mô tả giúp laravel hiểu tên bảng trong quá trình di chuyển.
Dành cho e. g. Cập nhật cột

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
6, chúng ta nên chạy lệnh như

php artisan make:migration update_name_column_in_contacts_table

Vào chế độ toàn màn hình Thoát chế độ toàn màn hình

Đọc thêm tại Laravel Doc

Công cụ sửa đổi cột

Công cụ sửa đổi cột không là gì ngoài một chức năng được xác định trước có sẵn trong LARAVEL Migration bằng cách sử dụng chức năng đó, bạn có thể tạo bất kỳ cột nào

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
7, Đặt cột
public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
8 và nhiều hơn nữa

Laravel bao gồm Eloquent, một trình ánh xạ quan hệ đối tượng [ORM] giúp tương tác với cơ sở dữ liệu của bạn trở nên thú vị. Khi sử dụng Eloquent, mỗi bảng cơ sở dữ liệu có một "Mô hình" tương ứng được sử dụng để tương tác với bảng đó. Ngoài việc truy xuất các bản ghi từ bảng cơ sở dữ liệu, các mô hình Eloquent còn cho phép bạn chèn, cập nhật và xóa các bản ghi khỏi bảng.

Lưu ý
Trước khi bắt đầu, hãy đảm bảo định cấu hình kết nối cơ sở dữ liệu trong tệp cấu hình

php artisan make:model Flight --migration

01 của ứng dụng của bạn. Để biết thêm thông tin về cách định cấu hình cơ sở dữ liệu của bạn, hãy xem tài liệu cấu hình cơ sở dữ liệu.

Trại khởi động Laravel

Nếu bạn chưa quen với Laravel, hãy thoải mái tham gia Laravel Bootcamp. Laravel Bootcamp sẽ hướng dẫn bạn cách xây dựng ứng dụng Laravel đầu tiên của bạn bằng Eloquent. Đó là một cách tuyệt vời để tham quan mọi thứ mà Laravel và Eloquent cung cấp

Tạo các lớp mô hình

Để bắt đầu, hãy tạo một mô hình Eloquent. Các mô hình thường nằm trong thư mục

php artisan make:model Flight --migration

02 và mở rộng lớp

php artisan make:model Flight --migration

03. Bạn có thể sử dụng lệnh Artisan

php artisan make:model Flight --migration

04 để tạo một mô hình mới

php artisan make:model Post -all
0

Nếu bạn muốn tạo di chuyển cơ sở dữ liệu khi tạo mô hình, bạn có thể sử dụng tùy chọn

php artisan make:model Flight --migration

05 hoặc

php artisan make:model Flight --migration

06

php artisan make:model Flight --migration

Bạn có thể tạo nhiều loại lớp khác nhau khi tạo mô hình, chẳng hạn như nhà máy, trình gieo hạt, chính sách, bộ điều khiển và yêu cầu biểu mẫu. Ngoài ra, các tùy chọn này có thể được kết hợp để tạo nhiều lớp cùng một lúc

php artisan make:model Post -all
4

kiểm tra mô hình

Đôi khi có thể khó xác định tất cả các thuộc tính và mối quan hệ có sẵn của một mô hình chỉ bằng cách lướt qua mã của nó. Thay vào đó, hãy thử lệnh Artisan

php artisan make:model Flight --migration

07, lệnh này cung cấp tổng quan thuận tiện về tất cả các thuộc tính và quan hệ của mô hình

php artisan make:model Post -all
6

Công ước mô hình hùng hồn

Các mô hình được tạo bởi lệnh

php artisan make:model Flight --migration

04 sẽ được đặt trong thư mục

php artisan make:model Flight --migration

09. Hãy kiểm tra một lớp mô hình cơ bản và thảo luận về một số quy ước chính của Eloquent

php artisan make:model Post -all
9

tên bảng

Sau khi xem qua ví dụ trên, bạn có thể nhận thấy rằng chúng tôi đã không cho Eloquent biết bảng cơ sở dữ liệu nào tương ứng với mô hình

php artisan make:model Flight --migration

10 của chúng tôi. Theo quy ước, "trường hợp rắn", tên số nhiều của lớp sẽ được sử dụng làm tên bảng trừ khi một tên khác được chỉ định rõ ràng. Vì vậy, trong trường hợp này, Eloquent sẽ giả sử mô hình

php artisan make:model Flight --migration

10 lưu trữ các bản ghi trong bảng

php artisan make:model Flight --migration

12, trong khi mô hình

php artisan make:model Flight --migration

13 sẽ lưu trữ các bản ghi trong bảng

php artisan make:model Flight --migration

14

Nếu bảng cơ sở dữ liệu tương ứng của mô hình của bạn không phù hợp với quy ước này, bạn có thể chỉ định tên bảng của mô hình theo cách thủ công bằng cách xác định thuộc tính

php artisan make:model Flight --migration

15 trên mô hình

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
6

Khóa chính

Eloquent cũng sẽ giả định rằng bảng cơ sở dữ liệu tương ứng của mỗi mô hình có một cột khóa chính có tên là

php artisan make:model Flight --migration

16. Nếu cần, bạn có thể xác định thuộc tính

php artisan make:model Flight --migration

17 được bảo vệ trên mô hình của mình để chỉ định một cột khác đóng vai trò là khóa chính của mô hình

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
9

Ngoài ra, Eloquent giả định rằng khóa chính là một giá trị số nguyên tăng dần, điều đó có nghĩa là Eloquent sẽ tự động chuyển khóa chính thành một số nguyên. Nếu bạn muốn sử dụng khóa chính không tăng dần hoặc không phải là số, bạn phải xác định thuộc tính

php artisan make:model Flight --migration

18 công khai trên mô hình của mình được đặt thành

php artisan make:model Flight --migration

19

php artisan make:migration update_name_column_in_contacts_table
2

Nếu khóa chính của mô hình của bạn không phải là số nguyên, thì bạn nên xác định thuộc tính

php artisan make:model Flight --migration

20 được bảo vệ trên mô hình của mình. Thuộc tính này phải có giá trị là

php artisan make:model Flight --migration

21

php artisan make:migration update_name_column_in_contacts_table
5

Khóa chính "tổng hợp"

Eloquent yêu cầu mỗi mô hình phải có ít nhất một "ID" nhận dạng duy nhất có thể đóng vai trò là khóa chính của nó. Các khóa chính "tổng hợp" không được hỗ trợ bởi các mô hình Eloquent. Tuy nhiên, bạn có thể tự do thêm các chỉ mục duy nhất, nhiều cột bổ sung vào các bảng cơ sở dữ liệu của mình ngoài khóa chính xác định duy nhất của bảng

Khóa UUID & ULID

Thay vì sử dụng số nguyên tăng tự động làm khóa chính của mô hình Eloquent, bạn có thể chọn sử dụng UUID thay thế. UUID là số nhận dạng chữ và số duy nhất trên toàn cầu dài 36 ký tự

Nếu bạn muốn một mô hình sử dụng khóa UUID thay vì khóa số nguyên tăng tự động, bạn có thể sử dụng đặc điểm

php artisan make:model Flight --migration

22 trên mô hình. Tất nhiên, bạn nên đảm bảo rằng mô hình có cột khóa chính tương đương UUID

php artisan make:migration update_name_column_in_contacts_table
7

Theo mặc định, Đặc điểm

php artisan make:model Flight --migration

23 sẽ tạo UUID "được sắp xếp" cho các mô hình của bạn. Các UUID này hiệu quả hơn cho việc lưu trữ cơ sở dữ liệu được lập chỉ mục vì chúng có thể được sắp xếp theo từ điển

Bạn có thể ghi đè quy trình tạo UUID cho một mô hình nhất định bằng cách xác định phương thức

php artisan make:model Flight --migration

24 trên mô hình. Ngoài ra, bạn có thể chỉ định cột nào sẽ nhận UUID bằng cách xác định phương thức

php artisan make:model Flight --migration

25 trên mô hình

php artisan make:model Flight --migration

0

Nếu muốn, bạn có thể chọn sử dụng "ULID" thay vì UUID. ULID tương tự như UUID; . Giống như các UUID được sắp xếp, các ULID có thể sắp xếp theo thứ tự từ điển để lập chỉ mục cơ sở dữ liệu hiệu quả. Để sử dụng ULID, bạn nên sử dụng đặc điểm

php artisan make:model Flight --migration

26 trên mô hình của mình. Bạn cũng nên đảm bảo rằng mô hình có cột khóa chính tương đương ULID

php artisan make:model Flight --migration

1

Dấu thời gian

Theo mặc định, Eloquent mong đợi các cột

php artisan make:model Flight --migration

27 và

php artisan make:model Flight --migration

28 tồn tại trên bảng cơ sở dữ liệu tương ứng của mô hình của bạn. Eloquent sẽ tự động đặt giá trị của các cột này khi các mô hình được tạo hoặc cập nhật. Nếu bạn không muốn Eloquent tự động quản lý các cột này, bạn nên xác định thuộc tính

php artisan make:model Flight --migration

29 trên mô hình của mình với giá trị là

php artisan make:model Flight --migration

19

php artisan make:model Flight --migration

2

Nếu bạn cần tùy chỉnh định dạng dấu thời gian của mô hình, hãy đặt thuộc tính

php artisan make:model Flight --migration

31 trên mô hình của bạn. Thuộc tính này xác định cách các thuộc tính ngày được lưu trữ trong cơ sở dữ liệu cũng như định dạng của chúng khi mô hình được tuần tự hóa thành một mảng hoặc JSON

php artisan make:model Flight --migration

3

Nếu bạn cần tùy chỉnh tên của các cột được sử dụng để lưu dấu thời gian, bạn có thể xác định các hằng số

php artisan make:model Flight --migration

32 và

php artisan make:model Flight --migration

33 trên mô hình của mình

php artisan make:model Flight --migration

4

Nếu bạn muốn thực hiện các hoạt động của mô hình mà không cần sửa đổi dấu thời gian của mô hình

php artisan make:model Flight --migration

28, bạn có thể thao tác trên mô hình trong phạm vi bao đóng được cung cấp cho phương thức

php artisan make:model Flight --migration

35

php artisan make:model Flight --migration

5

kết nối cơ sở dữ liệu

Theo mặc định, tất cả các mô hình Eloquent sẽ sử dụng kết nối cơ sở dữ liệu mặc định được định cấu hình cho ứng dụng của bạn. Nếu bạn muốn chỉ định một kết nối khác sẽ được sử dụng khi tương tác với một mô hình cụ thể, bạn nên xác định thuộc tính

php artisan make:model Flight --migration

36 trên mô hình

php artisan make:model Flight --migration

6

Giá trị thuộc tính mặc định

Theo mặc định, một phiên bản mô hình mới được khởi tạo sẽ không chứa bất kỳ giá trị thuộc tính nào. Nếu bạn muốn xác định các giá trị mặc định cho một số thuộc tính của mô hình, bạn có thể xác định thuộc tính

php artisan make:model Flight --migration

37 trên mô hình của mình

php artisan make:model Flight --migration

7

Cấu hình Eloquent Strictness

Laravel cung cấp một số phương thức cho phép bạn định cấu hình hành vi và "sự nghiêm ngặt" của Eloquent trong nhiều tình huống khác nhau

Đầu tiên, phương thức

php artisan make:model Flight --migration

38 chấp nhận một đối số boolean tùy chọn cho biết liệu có nên ngăn tải lười biếng hay không. Ví dụ: bạn có thể chỉ muốn tắt tính năng tải chậm trong môi trường phi sản xuất để môi trường sản xuất của bạn sẽ tiếp tục hoạt động bình thường ngay cả khi mối quan hệ tải chậm vô tình xuất hiện trong mã sản xuất. Thông thường, phương thức này nên được gọi trong phương thức

php artisan make:model Flight --migration

39 của ứng dụng của bạn

php artisan make:model Flight --migration

40

php artisan make:model Flight --migration

8

Ngoài ra, bạn có thể hướng dẫn Laravel ném một ngoại lệ khi cố điền một thuộc tính không thể điền bằng cách gọi phương thức

php artisan make:model Flight --migration

41. Điều này có thể giúp ngăn ngừa các lỗi không mong muốn trong quá trình phát triển cục bộ khi cố gắng đặt một thuộc tính chưa được thêm vào mảng

php artisan make:model Flight --migration

42 của mô hình

php artisan make:model Flight --migration

9

Cuối cùng, bạn có thể hướng dẫn Eloquent ném một ngoại lệ nếu bạn cố gắng truy cập một thuộc tính trên một mô hình khi thuộc tính đó không thực sự được lấy từ cơ sở dữ liệu hoặc khi thuộc tính không tồn tại. Ví dụ: điều này có thể xảy ra khi bạn quên thêm thuộc tính vào mệnh đề

php artisan make:model Flight --migration

43 của truy vấn Eloquent

php artisan make:model Post -all
40

Kích hoạt "Chế độ nghiêm ngặt" của Eloquent

Để thuận tiện, bạn có thể kích hoạt cả ba phương thức được thảo luận ở trên bằng cách gọi phương thức

php artisan make:model Flight --migration

44

php artisan make:model Post -all
41

Truy xuất mô hình

Khi bạn đã tạo một mô hình và bảng cơ sở dữ liệu được liên kết với nó, bạn đã sẵn sàng để bắt đầu truy xuất dữ liệu từ cơ sở dữ liệu của mình. Bạn có thể coi mỗi mô hình Eloquent là một trình tạo truy vấn mạnh mẽ cho phép bạn truy vấn trôi chảy bảng cơ sở dữ liệu được liên kết với mô hình. Phương thức

php artisan make:model Flight --migration

45 của mô hình sẽ lấy tất cả các bản ghi từ bảng cơ sở dữ liệu được liên kết của mô hình

php artisan make:model Post -all
42

truy vấn tòa nhà

Phương thức Eloquent

php artisan make:model Flight --migration

45 sẽ trả về tất cả các kết quả trong bảng của mô hình. Tuy nhiên, vì mỗi mô hình Eloquent đóng vai trò là trình tạo truy vấn, bạn có thể thêm các ràng buộc bổ sung cho truy vấn và sau đó gọi phương thức

php artisan make:model Flight --migration

47 để truy xuất kết quả

php artisan make:model Post -all
43

Lưu ý
Vì các mô hình Eloquent là trình tạo truy vấn, bạn nên xem lại tất cả các phương thức do trình tạo truy vấn của Laravel cung cấp. Bạn có thể sử dụng bất kỳ phương pháp nào trong số này khi viết truy vấn Eloquent của mình.

Làm mới người mẫu

Nếu bạn đã có một phiên bản của mô hình Eloquent được lấy từ cơ sở dữ liệu, bạn có thể "làm mới" mô hình bằng cách sử dụng các phương thức

php artisan make:model Flight --migration

48 và

php artisan make:model Flight --migration

49. Phương thức

php artisan make:model Flight --migration

48 sẽ lấy lại mô hình từ cơ sở dữ liệu. Phiên bản mô hình hiện tại sẽ không bị ảnh hưởng

php artisan make:model Post -all
44

Phương pháp

php artisan make:model Flight --migration

49 sẽ hydrat hóa lại mô hình hiện có bằng cách sử dụng dữ liệu mới từ cơ sở dữ liệu. Ngoài ra, tất cả các mối quan hệ đã tải của nó cũng sẽ được làm mới

php artisan make:model Post -all
45

bộ sưu tập

Như chúng ta đã thấy, các phương thức Eloquent như

php artisan make:model Flight --migration

45 và

php artisan make:model Flight --migration

47 lấy nhiều bản ghi từ cơ sở dữ liệu. Tuy nhiên, các phương thức này không trả về một mảng PHP đơn giản. Thay vào đó, một thể hiện của

php artisan make:model Flight --migration

54 được trả về

Lớp Eloquent

php artisan make:model Flight --migration

55 mở rộng lớp cơ sở

php artisan make:model Flight --migration

56 của Laravel, cung cấp nhiều phương thức hữu ích để tương tác với các bộ sưu tập dữ liệu. Ví dụ: phương pháp

php artisan make:model Flight --migration

57 có thể được sử dụng để xóa các mô hình khỏi bộ sưu tập dựa trên kết quả của một lần đóng được gọi

php artisan make:model Post -all
46

Ngoài các phương thức được cung cấp bởi class collection cơ sở của Laravel, class Eloquent collection còn cung cấp một số phương thức bổ sung dành riêng cho việc tương tác với các collection của Eloquent models

Vì tất cả các bộ sưu tập của Laravel đều triển khai các giao diện có thể lặp lại của PHP, nên bạn có thể lặp qua các bộ sưu tập như thể chúng là một mảng

php artisan make:model Post -all
47

Kết quả Chunking

Ứng dụng của bạn có thể hết bộ nhớ nếu bạn cố tải hàng chục nghìn bản ghi Eloquent thông qua phương thức

php artisan make:model Flight --migration

45 hoặc

php artisan make:model Flight --migration

47. Thay vì sử dụng các phương pháp này, phương pháp

php artisan make:model Flight --migration

60 có thể được sử dụng để xử lý số lượng lớn các mô hình hiệu quả hơn

Phương thức

php artisan make:model Flight --migration

60 sẽ truy xuất một tập hợp con của các mô hình Eloquent, chuyển chúng tới một bao đóng để xử lý. Vì mỗi lần chỉ truy xuất một đoạn mô hình Eloquent hiện tại, nên phương pháp

php artisan make:model Flight --migration

60 sẽ giúp giảm đáng kể mức sử dụng bộ nhớ khi làm việc với một số lượng lớn mô hình

php artisan make:model Post -all
48

Đối số đầu tiên được truyền cho phương thức

php artisan make:model Flight --migration

60 là số lượng bản ghi bạn muốn nhận trên mỗi "khối". Việc đóng được thông qua khi đối số thứ hai sẽ được gọi cho mỗi đoạn được truy xuất từ ​​​​cơ sở dữ liệu. Một truy vấn cơ sở dữ liệu sẽ được thực hiện để truy xuất từng đoạn bản ghi được chuyển đến phần đóng

Nếu bạn đang lọc kết quả của phương pháp

php artisan make:model Flight --migration

60 dựa trên một cột mà bạn cũng sẽ cập nhật trong khi lặp lại kết quả, bạn nên sử dụng phương pháp

php artisan make:model Flight --migration

65. Sử dụng phương pháp

php artisan make:model Flight --migration

60 trong các trường hợp này có thể dẫn đến kết quả không mong muốn và không nhất quán. Bên trong, phương thức

php artisan make:model Flight --migration

65 sẽ luôn truy xuất các mô hình có cột

php artisan make:model Flight --migration

16 lớn hơn mô hình cuối cùng trong đoạn trước

php artisan make:model Post -all
49

Chunking Sử dụng Lazy Collections

Phương thức

php artisan make:model Flight --migration

69 hoạt động tương tự như phương thức

php artisan make:model Flight --migration

60 theo nghĩa là, đằng sau hậu trường, nó thực thi truy vấn theo khối. Tuy nhiên, thay vì chuyển từng đoạn trực tiếp vào một hàm gọi lại như hiện tại, phương thức

php artisan make:model Flight --migration

69 trả về một

php artisan make:model Flight --migration

72 phẳng của các mô hình Eloquent, cho phép bạn tương tác với các kết quả dưới dạng một luồng duy nhất

php artisan make:model Post -all
60

Nếu bạn đang lọc kết quả của phương pháp

php artisan make:model Flight --migration

69 dựa trên một cột mà bạn cũng sẽ cập nhật trong khi lặp lại kết quả, bạn nên sử dụng phương pháp

php artisan make:model Flight --migration

74. Bên trong, phương thức

php artisan make:model Flight --migration

74 sẽ luôn truy xuất các mô hình có cột

php artisan make:model Flight --migration

16 lớn hơn mô hình cuối cùng trong đoạn trước

php artisan make:model Post -all
61

Bạn có thể lọc kết quả dựa trên thứ tự giảm dần của

php artisan make:model Flight --migration

16 bằng phương pháp

php artisan make:model Flight --migration

78

con trỏ

Tương tự như phương pháp

php artisan make:model Flight --migration

69, phương pháp

php artisan make:model Flight --migration

80 có thể được sử dụng để giảm đáng kể mức tiêu thụ bộ nhớ của ứng dụng khi lặp qua hàng chục nghìn bản ghi mô hình Eloquent

Phương thức

php artisan make:model Flight --migration

80 sẽ chỉ thực hiện một truy vấn cơ sở dữ liệu duy nhất; . Do đó, chỉ có một mô hình Eloquent được lưu trong bộ nhớ tại bất kỳ thời điểm nào trong khi lặp qua con trỏ

Cảnh báo
Vì phương thức

php artisan make:model Flight --migration

80 chỉ giữ một mô hình Eloquent duy nhất trong bộ nhớ tại một thời điểm, nên nó không thể háo hức tải các mối quan hệ. Nếu bạn cần háo hức tải các mối quan hệ, hãy cân nhắc sử dụng phương thức

php artisan make:model Flight --migration

69 để thay thế.

Bên trong, phương thức

php artisan make:model Flight --migration

80 sử dụng trình tạo PHP để triển khai chức năng này

php artisan make:model Post -all
62

php artisan make:model Flight --migration

80 trả về một phiên bản

php artisan make:model Flight --migration

86. Các bộ sưu tập lười biếng cho phép bạn sử dụng nhiều phương pháp bộ sưu tập có sẵn trên các bộ sưu tập điển hình của Laravel trong khi chỉ tải một mô hình duy nhất vào bộ nhớ tại một thời điểm

php artisan make:model Post -all
63

Mặc dù phương pháp

php artisan make:model Flight --migration

80 sử dụng ít bộ nhớ hơn nhiều so với truy vấn thông thường [bằng cách chỉ giữ một mô hình Eloquent duy nhất trong bộ nhớ tại một thời điểm], nhưng cuối cùng nó vẫn sẽ hết bộ nhớ. Điều này là do trình điều khiển PDO của PHP lưu trữ nội bộ tất cả các kết quả truy vấn thô trong bộ đệm của nó. Nếu bạn đang xử lý một số lượng rất lớn các bản ghi Eloquent, hãy cân nhắc sử dụng phương pháp

php artisan make:model Flight --migration

69 để thay thế

Truy vấn con nâng cao

Lựa chọn truy vấn con

Eloquent cũng cung cấp hỗ trợ truy vấn con nâng cao, cho phép bạn lấy thông tin từ các bảng có liên quan trong một truy vấn duy nhất. Ví dụ: hãy tưởng tượng rằng chúng ta có một bảng chuyến bay

php artisan make:model Flight --migration

89 và một bảng

php artisan make:model Flight --migration

12 đến các điểm đến. Bảng

php artisan make:model Flight --migration

12 chứa cột

php artisan make:model Flight --migration

92 cho biết thời điểm chuyến bay đến đích

Sử dụng chức năng truy vấn phụ có sẵn cho các phương pháp

php artisan make:model Flight --migration

43 và

php artisan make:model Flight --migration

94 của trình tạo truy vấn, chúng tôi có thể chọn tất cả

php artisan make:model Flight --migration

89 và tên của chuyến bay đã đến điểm đến đó gần đây nhất bằng một truy vấn duy nhất

php artisan make:model Post -all
64

Thứ tự truy vấn phụ

Ngoài ra, hàm

php artisan make:model Flight --migration

96 của trình tạo truy vấn hỗ trợ các truy vấn con. Tiếp tục sử dụng ví dụ về chuyến bay của chúng tôi, chúng tôi có thể sử dụng chức năng này để sắp xếp tất cả các điểm đến dựa trên thời điểm chuyến bay cuối cùng đến điểm đến đó. Một lần nữa, điều này có thể được thực hiện trong khi thực hiện một truy vấn cơ sở dữ liệu

php artisan make:model Post -all
65

Truy xuất các mô hình đơn lẻ / tổng hợp

Ngoài việc truy xuất tất cả các bản ghi phù hợp với một truy vấn nhất định, bạn cũng có thể truy xuất các bản ghi đơn lẻ bằng các phương pháp

php artisan make:model Flight --migration

97,

php artisan make:model Flight --migration

98 hoặc

php artisan make:model Flight --migration

99. Thay vì trả về một tập hợp các mô hình, các phương thức này trả về một phiên bản mô hình duy nhất

php artisan make:model Post -all
66

Đôi khi bạn có thể muốn thực hiện một số hành động khác nếu không tìm thấy kết quả. Các phương thức

php artisan make:model Post -all
400 và
php artisan make:model Post -all
401 sẽ trả về một phiên bản mô hình duy nhất hoặc nếu không tìm thấy kết quả nào, hãy thực hiện lệnh đóng đã cho. Giá trị trả về của bao đóng sẽ được coi là kết quả của phương thức

php artisan make:model Post -all
67

Không tìm thấy ngoại lệ

Đôi khi bạn có thể muốn ném một ngoại lệ nếu không tìm thấy mô hình. Điều này đặc biệt hữu ích trong các tuyến đường hoặc bộ điều khiển. Các phương thức

php artisan make:model Post -all
402 và
php artisan make:model Post -all
403 sẽ lấy kết quả đầu tiên của truy vấn;

php artisan make:model Post -all
68

Nếu không bắt được

php artisan make:model Post -all
405, phản hồi HTTP 404 sẽ tự động được gửi lại cho máy khách

php artisan make:model Post -all
69

Truy xuất hoặc tạo mô hình

Phương thức

php artisan make:model Post -all
406 sẽ cố gắng định vị một bản ghi cơ sở dữ liệu bằng cách sử dụng các cặp cột/giá trị đã cho. Nếu không thể tìm thấy mô hình trong cơ sở dữ liệu, một bản ghi sẽ được chèn với các thuộc tính do hợp nhất đối số mảng thứ nhất với đối số mảng thứ hai tùy chọn

Phương thức

php artisan make:model Post -all
407, giống như
php artisan make:model Post -all
406, sẽ cố gắng xác định vị trí một bản ghi trong cơ sở dữ liệu khớp với các thuộc tính đã cho. Tuy nhiên, nếu không tìm thấy mô hình, một phiên bản mô hình mới sẽ được trả về. Lưu ý rằng mô hình được trả về bởi
php artisan make:model Post -all
407 vẫn chưa được lưu vào cơ sở dữ liệu. Bạn sẽ cần gọi thủ công phương thức
php artisan make:model Post -all
410 để duy trì nó

php artisan make:model Post -all
90

Truy xuất tổng hợp

Khi tương tác với các mô hình Eloquent, bạn cũng có thể sử dụng các phương thức

php artisan make:model Post -all
411,
php artisan make:model Post -all
412,
php artisan make:model Post -all
413 và các phương thức tổng hợp khác do trình tạo truy vấn Laravel cung cấp. Như bạn có thể mong đợi, các phương thức này trả về một giá trị vô hướng thay vì một thể hiện của Eloquent model

php artisan make:model Post -all
91

Chèn và cập nhật mô hình

phụ trang

Tất nhiên, khi sử dụng Eloquent, chúng ta không chỉ cần lấy các model từ cơ sở dữ liệu. Chúng ta cũng cần chèn các bản ghi mới. Rất may, Eloquent làm cho nó đơn giản. Để chèn một bản ghi mới vào cơ sở dữ liệu, bạn nên khởi tạo một phiên bản mô hình mới và đặt các thuộc tính trên mô hình. Sau đó, gọi phương thức

php artisan make:model Post -all
410 trên phiên bản mô hình

php artisan make:model Post -all
92

Trong ví dụ này, chúng tôi chỉ định trường

php artisan make:model Post -all
415 từ yêu cầu HTTP đến cho thuộc tính
php artisan make:model Post -all
415 của phiên bản mô hình
php artisan make:model Post -all
417. Khi chúng ta gọi phương thức
php artisan make:model Post -all
410, một bản ghi sẽ được chèn vào cơ sở dữ liệu. Dấu thời gian

php artisan make:model Flight --migration

27 và

php artisan make:model Flight --migration

28 của mô hình sẽ tự động được đặt khi phương thức
php artisan make:model Post -all
410 được gọi, vì vậy không cần phải đặt chúng theo cách thủ công

Ngoài ra, bạn có thể sử dụng phương thức

php artisan make:model Post -all
422 để "lưu" một mô hình mới bằng một câu lệnh PHP. Phiên bản mô hình được chèn sẽ được trả về cho bạn bằng phương thức
php artisan make:model Post -all
422

php artisan make:model Post -all
93

Tuy nhiên, trước khi sử dụng phương thức

php artisan make:model Post -all
422, bạn cần chỉ định thuộc tính

php artisan make:model Flight --migration

42 hoặc
php artisan make:model Post -all
426 trên lớp mô hình của mình. Các thuộc tính này là bắt buộc vì tất cả các mô hình Eloquent đều được bảo vệ khỏi các lỗ hổng gán hàng loạt theo mặc định. Để tìm hiểu thêm về phép gán hàng loạt, vui lòng tham khảo tài liệu về phép gán hàng loạt

cập nhật

Phương pháp

php artisan make:model Post -all
410 cũng có thể được sử dụng để cập nhật các mô hình đã tồn tại trong cơ sở dữ liệu. Để cập nhật một mô hình, bạn nên truy xuất mô hình đó và đặt bất kỳ thuộc tính nào bạn muốn cập nhật. Sau đó, bạn nên gọi phương thức
php artisan make:model Post -all
410 của mô hình. Một lần nữa, dấu thời gian

php artisan make:model Flight --migration

28 sẽ tự động được cập nhật, do đó không cần phải đặt giá trị của nó theo cách thủ công

php artisan make:model Post -all
94

Cập nhật hàng loạt

Cập nhật cũng có thể được thực hiện đối với các mô hình phù hợp với một truy vấn nhất định. Trong ví dụ này, tất cả các chuyến bay là ____1430 và có ____1431 của ____1432 sẽ được đánh dấu là bị hoãn

php artisan make:model Post -all
95

Phương thức

php artisan make:model Post -all
433 yêu cầu một mảng các cặp cột và giá trị đại diện cho các cột cần được cập nhật. Phương thức
php artisan make:model Post -all
433 trả về số hàng bị ảnh hưởng

Cảnh báo
Khi phát hành bản cập nhật hàng loạt qua Eloquent, các sự kiện mô hình

php artisan make:model Post -all
435,
php artisan make:model Post -all
436,
php artisan make:model Post -all
437 và
php artisan make:model Post -all
438 sẽ không được kích hoạt cho các mô hình đã cập nhật. Điều này là do các mô hình không bao giờ thực sự được truy xuất khi phát hành bản cập nhật hàng loạt.

Kiểm tra thay đổi thuộc tính

Eloquent cung cấp các phương thức

php artisan make:model Post -all
439,
php artisan make:model Post -all
440 và
php artisan make:model Post -all
441 để kiểm tra trạng thái bên trong mô hình của bạn và xác định các thuộc tính của nó đã thay đổi như thế nào so với khi mô hình được truy xuất ban đầu

Phương thức

php artisan make:model Post -all
439 xác định xem có bất kỳ thuộc tính nào của mô hình đã bị thay đổi kể từ khi mô hình được truy xuất hay không. Bạn có thể chuyển một tên thuộc tính cụ thể hoặc một mảng thuộc tính cho phương thức
php artisan make:model Post -all
439 để xác định xem có thuộc tính nào "bẩn" không. Phương thức
php artisan make:model Post -all
440 sẽ xác định xem một thuộc tính có không thay đổi kể từ khi mô hình được truy xuất hay không. Phương thức này cũng chấp nhận một đối số thuộc tính tùy chọn

php artisan make:model Post -all
96

Phương thức

php artisan make:model Post -all
441 xác định xem có bất kỳ thuộc tính nào bị thay đổi khi mô hình được lưu lần cuối trong chu kỳ yêu cầu hiện tại hay không. Nếu cần, bạn có thể chuyển tên thuộc tính để xem liệu một thuộc tính cụ thể có bị thay đổi hay không

php artisan make:model Post -all
97

Phương thức

php artisan make:model Post -all
446 trả về một mảng chứa các thuộc tính ban đầu của mô hình bất kể có bất kỳ thay đổi nào đối với mô hình kể từ khi nó được truy xuất. Nếu cần, bạn có thể chuyển một tên thuộc tính cụ thể để lấy giá trị ban đầu của một thuộc tính cụ thể

php artisan make:model Post -all
98

chuyển nhượng hàng loạt

Bạn có thể sử dụng phương thức

php artisan make:model Post -all
422 để "lưu" một mô hình mới bằng một câu lệnh PHP. Phiên bản mô hình được chèn sẽ được trả về cho bạn theo phương thức

php artisan make:model Post -all
93

Tuy nhiên, trước khi sử dụng phương thức

php artisan make:model Post -all
422, bạn cần chỉ định thuộc tính

php artisan make:model Flight --migration

42 hoặc
php artisan make:model Post -all
426 trên lớp mô hình của mình. Các thuộc tính này là bắt buộc vì tất cả các mô hình Eloquent đều được bảo vệ khỏi các lỗ hổng gán hàng loạt theo mặc định

Lỗ hổng gán hàng loạt xảy ra khi người dùng chuyển một trường yêu cầu HTTP không mong muốn và trường đó thay đổi một cột trong cơ sở dữ liệu của bạn mà bạn không mong đợi. Ví dụ: người dùng ác ý có thể gửi tham số

php artisan make:model Post -all
451 thông qua yêu cầu HTTP, sau đó yêu cầu này được chuyển đến phương thức
php artisan make:model Post -all
422 của mô hình của bạn, cho phép người dùng tự báo cáo với quản trị viên

Vì vậy, để bắt đầu, bạn nên xác định thuộc tính mô hình nào bạn muốn gán hàng loạt. Bạn có thể làm điều này bằng cách sử dụng thuộc tính

php artisan make:model Post -all
453 trên mô hình. Ví dụ: hãy đặt thuộc tính
php artisan make:model Post -all
415 của mô hình

php artisan make:model Flight --migration

10 có thể gán khối lượng

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
60

Khi bạn đã chỉ định thuộc tính nào có thể gán hàng loạt, bạn có thể sử dụng phương thức

php artisan make:model Post -all
422 để chèn bản ghi mới vào cơ sở dữ liệu. Phương thức
php artisan make:model Post -all
422 trả về thể hiện mô hình mới được tạo

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
61

Nếu bạn đã có một phiên bản mô hình, bạn có thể sử dụng phương thức

php artisan make:model Post -all
458 để điền vào đó một mảng các thuộc tính

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
62

Chuyển nhượng hàng loạt & cột JSON

Khi gán các cột JSON, khóa có thể gán hàng loạt của mỗi cột phải được chỉ định trong mảng

php artisan make:model Post -all
453 của mô hình của bạn. Để bảo mật, Laravel không hỗ trợ cập nhật các thuộc tính JSON lồng nhau khi sử dụng thuộc tính
php artisan make:model Post -all
426

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
63

Cho phép chuyển nhượng hàng loạt

Nếu bạn muốn làm cho tất cả các thuộc tính của mình có thể được gán hàng loạt, bạn có thể xác định thuộc tính

php artisan make:model Post -all
461 của mô hình của mình dưới dạng một mảng trống. Nếu bạn chọn không bảo vệ mô hình của mình, bạn nên đặc biệt cẩn thận để luôn tạo thủ công các mảng được truyền cho các phương thức
php artisan make:model Post -all
458,
php artisan make:model Post -all
422 và
php artisan make:model Post -all
433 của Eloquent

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
64

Ngoại lệ chuyển nhượng hàng loạt

Theo mặc định, các thuộc tính không được bao gồm trong mảng

php artisan make:model Post -all
453 sẽ bị loại bỏ một cách âm thầm khi thực hiện các thao tác gán hàng loạt. Trong sản xuất, đây là hành vi dự kiến;

Nếu muốn, bạn có thể hướng dẫn Laravel ném một ngoại lệ khi cố điền một thuộc tính không thể điền bằng cách gọi phương thức

php artisan make:model Flight --migration

41. Thông thường, phương thức này nên được gọi trong phương thức

php artisan make:model Flight --migration

39 của một trong những nhà cung cấp dịch vụ của ứng dụng của bạn

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
65

Upserts

Đôi khi, bạn có thể cần cập nhật mô hình hiện có hoặc tạo mô hình mới nếu không có mô hình phù hợp. Giống như phương thức

php artisan make:model Post -all
406, phương thức
php artisan make:model Post -all
469 vẫn duy trì mô hình, vì vậy không cần phải gọi phương thức
php artisan make:model Post -all
410 theo cách thủ công

Trong ví dụ dưới đây, nếu một chuyến bay tồn tại với vị trí

php artisan make:model Post -all
471 của
php artisan make:model Post -all
472 và vị trí
php artisan make:model Post -all
431 của
php artisan make:model Post -all
432, các cột
php artisan make:model Post -all
475 và
php artisan make:model Post -all
476 của chuyến bay đó sẽ được cập nhật. Nếu không có chuyến bay nào như vậy tồn tại, một chuyến bay mới sẽ được tạo có các thuộc tính do hợp nhất mảng đối số thứ nhất với mảng đối số thứ hai

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
66

Nếu bạn muốn thực hiện nhiều "uperts" trong một truy vấn, thì bạn nên sử dụng phương thức

php artisan make:model Post -all
477 để thay thế. Đối số đầu tiên của phương thức bao gồm các giá trị để chèn hoặc cập nhật, trong khi đối số thứ hai liệt kê [các] cột xác định duy nhất các bản ghi trong bảng được liên kết. Đối số thứ ba và cũng là đối số cuối cùng của phương thức là một mảng các cột sẽ được cập nhật nếu một bản ghi phù hợp đã tồn tại trong cơ sở dữ liệu. Phương pháp
php artisan make:model Post -all
477 sẽ tự động đặt dấu thời gian

php artisan make:model Flight --migration

27 và

php artisan make:model Flight --migration

28 nếu dấu thời gian được bật trên mô hình

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
67

Cảnh báo
Tất cả các cơ sở dữ liệu ngoại trừ SQL Server đều yêu cầu các cột trong đối số thứ hai của phương thức

php artisan make:model Post -all
477 phải có chỉ mục "chính" hoặc "duy nhất". Ngoài ra, trình điều khiển cơ sở dữ liệu MySQL bỏ qua đối số thứ hai của phương thức
php artisan make:model Post -all
477 và luôn sử dụng các chỉ mục "chính" và "duy nhất" của bảng để phát hiện các bản ghi hiện có.

Xóa mô hình

Để xóa một mô hình, bạn có thể gọi phương thức

php artisan make:model Post -all
483 trên phiên bản mô hình

Bạn có thể gọi phương thức

php artisan make:model Post -all
484 để xóa tất cả các bản ghi cơ sở dữ liệu liên quan của mô hình. Thao tác
php artisan make:model Post -all
484 cũng sẽ đặt lại mọi ID tăng tự động trên bảng được liên kết của mô hình

Xóa một mô hình hiện có bằng khóa chính của nó

Trong ví dụ trên, chúng tôi đang truy xuất mô hình từ cơ sở dữ liệu trước khi gọi phương thức

php artisan make:model Post -all
483. Tuy nhiên, nếu bạn biết khóa chính của mô hình, bạn có thể xóa mô hình mà không truy xuất nó một cách rõ ràng bằng cách gọi phương thức
php artisan make:model Post -all
487. Ngoài việc chấp nhận một khóa chính duy nhất, phương thức
php artisan make:model Post -all
487 sẽ chấp nhận nhiều khóa chính, một mảng khóa chính hoặc tập hợp các khóa chính

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
68

Cảnh báo
Phương thức

php artisan make:model Post -all
487 tải từng mô hình riêng lẻ và gọi phương thức
php artisan make:model Post -all
483 để các sự kiện
php artisan make:model Post -all
491 và
php artisan make:model Post -all
492 được gửi chính xác cho từng mô hình.

Xóa mô hình bằng truy vấn

Tất nhiên, bạn có thể tạo truy vấn Eloquent để xóa tất cả các mô hình phù hợp với tiêu chí truy vấn của bạn. Trong ví dụ này, chúng tôi sẽ xóa tất cả các chuyến bay được đánh dấu là không hoạt động. Giống như cập nhật hàng loạt, xóa hàng loạt sẽ không gửi các sự kiện mô hình cho các mô hình bị xóa

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
69

Cảnh báo
Khi thực hiện lệnh xóa hàng loạt qua Eloquent, các sự kiện mô hình

php artisan make:model Post -all
491 và
php artisan make:model Post -all
492 sẽ không được gửi cho các mô hình đã xóa. Điều này là do các mô hình không bao giờ thực sự được truy xuất khi thực hiện câu lệnh xóa.

Xóa mềm

Ngoài việc thực sự xóa các bản ghi khỏi cơ sở dữ liệu của bạn, Eloquent còn có thể "xóa mềm" các mô hình. Khi các mô hình bị xóa mềm, chúng không thực sự bị xóa khỏi cơ sở dữ liệu của bạn. Thay vào đó, một thuộc tính

php artisan make:model Post -all
495 được đặt trên mô hình cho biết ngày và giờ mà mô hình bị "xóa". Để kích hoạt xóa mềm cho một mô hình, hãy thêm đặc điểm
php artisan make:model Post -all
496 vào mô hình

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
90

Lưu ý
Đặc điểm

php artisan make:model Post -all
497 sẽ tự động chuyển thuộc tính
php artisan make:model Post -all
495 thành phiên bản
php artisan make:model Post -all
499 /
php artisan make:model Post -all
600 cho bạn.

Bạn cũng nên thêm cột

php artisan make:model Post -all
495 vào bảng cơ sở dữ liệu của mình. Trình tạo lược đồ Laravel chứa một phương thức trợ giúp để tạo cột này

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
91

Bây giờ, khi bạn gọi phương thức

php artisan make:model Post -all
483 trên model, cột
php artisan make:model Post -all
495 sẽ được đặt thành ngày và giờ hiện tại. Tuy nhiên, bản ghi cơ sở dữ liệu của mô hình sẽ được để lại trong bảng. Khi truy vấn một mô hình sử dụng xóa mềm, các mô hình đã xóa mềm sẽ tự động bị loại khỏi tất cả các kết quả truy vấn

Để xác định xem một phiên bản mô hình nhất định đã bị xóa mềm hay chưa, bạn có thể sử dụng phương pháp

php artisan make:model Post -all
604

Khôi phục các mô hình đã xóa mềm

Đôi khi bạn có thể muốn "hủy xóa" một mô hình đã xóa mềm. Để khôi phục một mô hình đã xóa mềm, bạn có thể gọi phương thức

php artisan make:model Post -all
605 trên một phiên bản mô hình. Phương pháp
php artisan make:model Post -all
605 sẽ đặt cột
php artisan make:model Post -all
495 của mô hình thành
php artisan make:model Post -all
608

Bạn cũng có thể sử dụng phương pháp

php artisan make:model Post -all
605 trong truy vấn để khôi phục nhiều kiểu máy. Một lần nữa, giống như các hoạt động "khối lượng" khác, thao tác này sẽ không gửi bất kỳ sự kiện mô hình nào cho các mô hình được khôi phục

Phương pháp

php artisan make:model Post -all
605 cũng có thể được sử dụng khi xây dựng các truy vấn mối quan hệ

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
92

Xóa vĩnh viễn các mô hình

Đôi khi bạn có thể cần thực sự xóa một mô hình khỏi cơ sở dữ liệu của mình. Bạn có thể sử dụng phương pháp

php artisan make:model Post -all
611 để xóa vĩnh viễn mô hình đã xóa mềm khỏi bảng cơ sở dữ liệu

Bạn cũng có thể sử dụng phương thức

php artisan make:model Post -all
611 khi xây dựng các truy vấn quan hệ Eloquent

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
93

Truy vấn các mô hình đã xóa mềm

Bao gồm cả các mô hình đã xóa mềm

Như đã lưu ý ở trên, các mô hình đã xóa mềm sẽ tự động bị loại khỏi kết quả truy vấn. Tuy nhiên, bạn có thể buộc các mô hình đã xóa mềm được đưa vào kết quả của truy vấn bằng cách gọi phương thức

php artisan make:model Post -all
613 trên truy vấn

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
94

Phương thức

php artisan make:model Post -all
613 cũng có thể được gọi khi xây dựng truy vấn mối quan hệ

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
95

Chỉ truy xuất các mô hình đã xóa mềm

Phương pháp

php artisan make:model Post -all
615 sẽ chỉ truy xuất các mô hình đã xóa mềm

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
96

Mô hình cắt tỉa

Đôi khi bạn có thể muốn xóa định kỳ các mô hình không còn cần thiết. Để thực hiện điều này, bạn có thể thêm đặc điểm

php artisan make:model Post -all
616 hoặc
php artisan make:model Post -all
617 vào các mô hình mà bạn muốn cắt tỉa định kỳ. Sau khi thêm một trong các đặc điểm vào mô hình, hãy triển khai phương thức
php artisan make:model Post -all
618 trả về trình tạo truy vấn Eloquent để giải quyết các mô hình không còn cần thiết

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
97

Khi đánh dấu các mô hình là

php artisan make:model Post -all
619, bạn cũng có thể xác định một phương pháp
php artisan make:model Post -all
620 trên mô hình. Phương thức này sẽ được gọi trước khi mô hình bị xóa. Phương pháp này có thể hữu ích để xóa bất kỳ tài nguyên bổ sung nào được liên kết với mô hình, chẳng hạn như các tệp được lưu trữ, trước khi mô hình bị xóa vĩnh viễn khỏi cơ sở dữ liệu

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
98

Sau khi định cấu hình mô hình có thể cắt được của bạn, bạn nên lên lịch cho lệnh Artisan

php artisan make:model Post -all
621 trong lớp
php artisan make:model Post -all
622 của ứng dụng của bạn. Bạn có thể tự do chọn khoảng thời gian thích hợp để chạy lệnh này

public function up[]
{
    Schema::create['contacts', function [Blueprint $table] 
    {
            $table->id[];
            $table->string['name'];
            $table->string['mobile_no'];
            $table->boolean['status'];
            $table->timestamps[];
    }];
}
99

Đằng sau hậu trường, lệnh

php artisan make:model Post -all
621 sẽ tự động phát hiện các mô hình "Có thể cắt được" trong thư mục

php artisan make:model Flight --migration

09 của ứng dụng của bạn. Nếu các mô hình của bạn ở một vị trí khác, bạn có thể sử dụng tùy chọn
php artisan make:model Post -all
625 để chỉ định tên lớp mô hình

php artisan make:migration update_name_column_in_contacts_table
20

Nếu bạn muốn loại trừ một số mô hình khỏi bị cắt tỉa trong khi cắt tỉa tất cả các mô hình được phát hiện khác, bạn có thể sử dụng tùy chọn

php artisan make:model Post -all
626

php artisan make:migration update_name_column_in_contacts_table
21

Bạn có thể kiểm tra truy vấn

php artisan make:model Post -all
618 của mình bằng cách thực hiện lệnh
php artisan make:model Post -all
621 với tùy chọn
php artisan make:model Post -all
629. Khi giả vờ, lệnh
php artisan make:model Post -all
621 sẽ chỉ báo cáo có bao nhiêu bản ghi sẽ bị cắt bớt nếu lệnh thực sự chạy

php artisan make:migration update_name_column_in_contacts_table
22

Cảnh báo
Các mô hình xóa mềm sẽ bị xóa vĩnh viễn [

php artisan make:model Post -all
611] nếu chúng phù hợp với truy vấn có thể cắt được.

cắt tỉa hàng loạt

Khi các mô hình được đánh dấu bằng đặc điểm

php artisan make:model Post -all
617, các mô hình sẽ bị xóa khỏi cơ sở dữ liệu bằng truy vấn xóa hàng loạt. Do đó, phương pháp
php artisan make:model Post -all
620 sẽ không được gọi, cũng như các sự kiện mô hình
php artisan make:model Post -all
491 và
php artisan make:model Post -all
492 sẽ không được gửi đi. Điều này là do các mô hình không bao giờ thực sự được truy xuất trước khi xóa, do đó làm cho quá trình cắt tỉa hiệu quả hơn nhiều

php artisan make:migration update_name_column_in_contacts_table
23

Sao chép mô hình

Bạn có thể tạo một bản sao chưa lưu của một phiên bản mô hình hiện có bằng cách sử dụng phương thức

php artisan make:model Post -all
636. Phương pháp này đặc biệt hữu ích khi bạn có các phiên bản mô hình chia sẻ nhiều thuộc tính giống nhau

php artisan make:migration update_name_column_in_contacts_table
24

Để loại trừ một hoặc nhiều thuộc tính không được sao chép sang mô hình mới, bạn có thể chuyển một mảng cho phương thức

php artisan make:model Post -all
636

php artisan make:migration update_name_column_in_contacts_table
25

Phạm vi truy vấn

Phạm vi toàn cầu

Phạm vi toàn cầu cho phép bạn thêm các ràng buộc vào tất cả các truy vấn cho một mô hình nhất định. Chức năng xóa mềm của Laravel sử dụng phạm vi toàn cầu để chỉ truy xuất các mô hình "không bị xóa" khỏi cơ sở dữ liệu. Viết phạm vi toàn cầu của riêng bạn có thể cung cấp một cách thuận tiện, dễ dàng để đảm bảo mọi truy vấn cho một mô hình nhất định đều nhận được các ràng buộc nhất định

Viết phạm vi toàn cầu

Viết một phạm vi toàn cầu là đơn giản. Đầu tiên, xác định một lớp triển khai giao diện

php artisan make:model Post -all
638. Laravel không có một vị trí thông thường để bạn đặt các lớp phạm vi, vì vậy bạn có thể đặt lớp này vào bất kỳ thư mục nào bạn muốn

Giao diện

php artisan make:model Post -all
639 yêu cầu bạn triển khai một phương thức.
php artisan make:model Post -all
640. Phương pháp
php artisan make:model Post -all
640 có thể thêm các ràng buộc
php artisan make:model Post -all
642 hoặc các loại mệnh đề khác vào truy vấn khi cần

php artisan make:migration update_name_column_in_contacts_table
26

Lưu ý
Nếu phạm vi toàn cầu của bạn đang thêm các cột vào mệnh đề select của truy vấn, bạn nên sử dụng phương thức

php artisan make:model Flight --migration

94 thay vì

php artisan make:model Flight --migration

43. Điều này sẽ ngăn việc thay thế không chủ ý mệnh đề select hiện có của truy vấn.

Áp dụng phạm vi toàn cầu

Để gán phạm vi toàn cầu cho một mô hình, bạn nên ghi đè phương thức

php artisan make:model Post -all
645 của mô hình và gọi phương thức
php artisan make:model Post -all
646 của mô hình. Phương thức
php artisan make:model Post -all
646 chấp nhận một thể hiện trong phạm vi của bạn làm đối số duy nhất của nó

php artisan make:migration update_name_column_in_contacts_table
27

Sau khi thêm phạm vi trong ví dụ trên vào mô hình

php artisan make:model Post -all
648, lệnh gọi phương thức
php artisan make:model Post -all
649 sẽ thực thi truy vấn SQL sau

php artisan make:migration update_name_column_in_contacts_table
28

Phạm vi toàn cầu ẩn danh

Eloquent cũng cho phép bạn xác định các phạm vi toàn cầu bằng cách sử dụng các bao đóng, điều này đặc biệt hữu ích cho các phạm vi đơn giản không đảm bảo một lớp riêng biệt của riêng chúng. Khi xác định phạm vi toàn cầu bằng cách sử dụng bao đóng, bạn nên cung cấp tên phạm vi do chính bạn chọn làm đối số đầu tiên cho phương thức

php artisan make:model Post -all
646

php artisan make:migration update_name_column_in_contacts_table
29

Loại bỏ phạm vi toàn cầu

Nếu bạn muốn xóa phạm vi toàn cầu cho một truy vấn nhất định, bạn có thể sử dụng phương pháp

php artisan make:model Post -all
651. Phương thức này chấp nhận tên lớp của phạm vi toàn cầu làm đối số duy nhất của nó

php artisan make:migration update_name_column_in_contacts_table
50

Hoặc, nếu bạn đã xác định phạm vi toàn cầu bằng bao đóng, bạn nên chuyển tên chuỗi mà bạn đã gán cho phạm vi toàn cầu

php artisan make:migration update_name_column_in_contacts_table
51

Nếu bạn muốn xóa một số hoặc thậm chí tất cả phạm vi toàn cầu của truy vấn, bạn có thể sử dụng phương pháp

php artisan make:model Post -all
652

php artisan make:migration update_name_column_in_contacts_table
52

Phạm vi cục bộ

Phạm vi cục bộ cho phép bạn xác định các bộ ràng buộc truy vấn phổ biến mà bạn có thể dễ dàng sử dụng lại trong ứng dụng của mình. Ví dụ: bạn có thể cần thường xuyên truy xuất tất cả người dùng được coi là "phổ biến". Để xác định phạm vi, thêm tiền tố vào một phương thức mô hình Eloquent bằng

php artisan make:model Post -all
653

Phạm vi phải luôn trả về cùng một phiên bản trình tạo truy vấn hoặc

php artisan make:model Post -all
654

php artisan make:migration update_name_column_in_contacts_table
53

Sử dụng phạm vi cục bộ

Khi phạm vi đã được xác định, bạn có thể gọi các phương thức phạm vi khi truy vấn mô hình. Tuy nhiên, bạn không nên bao gồm tiền tố

php artisan make:model Post -all
653 khi gọi phương thức. Bạn thậm chí có thể xâu chuỗi các cuộc gọi đến các phạm vi khác nhau

php artisan make:migration update_name_column_in_contacts_table
54

Kết hợp nhiều phạm vi mô hình Eloquent thông qua toán tử truy vấn

php artisan make:model Post -all
656 có thể yêu cầu sử dụng các bao đóng để đạt được nhóm logic chính xác

php artisan make:migration update_name_column_in_contacts_table
55

Tuy nhiên, vì điều này có thể rườm rà, nên Laravel cung cấp một phương thức

php artisan make:model Post -all
657 "bậc cao hơn" cho phép bạn xâu chuỗi các phạm vi lại với nhau một cách trôi chảy mà không cần sử dụng bao đóng

php artisan make:migration update_name_column_in_contacts_table
56

Phạm vi động

Đôi khi bạn có thể muốn xác định một phạm vi chấp nhận các tham số. Để bắt đầu, chỉ cần thêm các tham số bổ sung vào chữ ký của phương thức phạm vi của bạn. Tham số phạm vi phải được xác định sau tham số

php artisan make:model Post -all
658

php artisan make:migration update_name_column_in_contacts_table
57

Khi các đối số dự kiến ​​đã được thêm vào chữ ký của phương thức phạm vi của bạn, bạn có thể chuyển các đối số khi gọi phạm vi

php artisan make:migration update_name_column_in_contacts_table
58

So sánh các mô hình

Đôi khi bạn có thể cần xác định xem hai mô hình có "giống nhau" hay không. Các phương pháp

php artisan make:model Post -all
659 và
php artisan make:model Post -all
660 có thể được sử dụng để nhanh chóng xác minh hai mô hình có cùng khóa chính, bảng và kết nối cơ sở dữ liệu hay không

php artisan make:migration update_name_column_in_contacts_table
59

Các phương thức

php artisan make:model Post -all
659 và
php artisan make:model Post -all
660 cũng khả dụng khi sử dụng các mối quan hệ
php artisan make:model Post -all
663,
php artisan make:model Post -all
664,
php artisan make:model Post -all
665 và
php artisan make:model Post -all
666. Phương pháp này đặc biệt hữu ích khi bạn muốn so sánh một mô hình có liên quan mà không đưa ra truy vấn để truy xuất mô hình đó

php artisan make:migration update_name_column_in_contacts_table
70

Sự kiện

Lưu ý
Bạn muốn phát trực tiếp các sự kiện Eloquent tới ứng dụng phía máy khách của mình? .

Các mô hình Eloquent gửi một số sự kiện, cho phép bạn kết nối với những khoảnh khắc sau trong vòng đời của một mô hình.

php artisan make:model Post -all
667,
php artisan make:model Post -all
668,
php artisan make:model Post -all
669,
php artisan make:model Post -all
437,
php artisan make:model Post -all
438,
php artisan make:model Post -all
435,
php artisan make:model Post -all
436,
php artisan make:model Post -all
491,
php artisan make:model Post -all
492,
php artisan make:model Post -all
604,
php artisan make:model Post -all
677,
php artisan make:model Post -all
678,
php artisan make:model Post -all
679, và
php artisan make:model Post -all
680

Sự kiện

php artisan make:model Post -all
667 sẽ gửi đi khi một mô hình hiện có được lấy từ cơ sở dữ liệu. Khi một mô hình mới được lưu lần đầu tiên, các sự kiện
php artisan make:model Post -all
668 và
php artisan make:model Post -all
669 sẽ gửi đi. Các sự kiện
php artisan make:model Post -all
437 /
php artisan make:model Post -all
438 sẽ gửi đi khi một mô hình hiện có được sửa đổi và phương thức
php artisan make:model Post -all
410 được gọi. Các sự kiện
php artisan make:model Post -all
435 /
php artisan make:model Post -all
436 sẽ gửi đi khi một mô hình được tạo hoặc cập nhật - ngay cả khi các thuộc tính của mô hình không bị thay đổi. Tên sự kiện kết thúc bằng
php artisan make:model Post -all
689 được gửi đi trước khi bất kỳ thay đổi nào đối với mô hình được duy trì, trong khi các sự kiện kết thúc bằng
php artisan make:model Post -all
690 được gửi đi sau khi các thay đổi đối với mô hình được duy trì

Để bắt đầu lắng nghe các sự kiện mô hình, hãy xác định thuộc tính

php artisan make:model Post -all
691 trên mô hình Eloquent của bạn. Thuộc tính này ánh xạ các điểm khác nhau trong vòng đời của mô hình Eloquent tới các lớp sự kiện của riêng bạn. Mỗi lớp sự kiện mô hình sẽ nhận được một phiên bản của mô hình bị ảnh hưởng thông qua hàm tạo của nó

php artisan make:migration update_name_column_in_contacts_table
71

Sau khi xác định và ánh xạ các sự kiện Eloquent của bạn, bạn có thể sử dụng các trình lắng nghe sự kiện để xử lý các sự kiện

Cảnh báo
Khi thực hiện cập nhật hàng loạt hoặc xóa truy vấn qua Eloquent, các sự kiện mô hình

php artisan make:model Post -all
436,
php artisan make:model Post -all
438,
php artisan make:model Post -all
491 và
php artisan make:model Post -all
492 sẽ không được gửi cho các mô hình bị ảnh hưởng. Điều này là do các mô hình không bao giờ thực sự được truy xuất khi thực hiện cập nhật hoặc xóa hàng loạt.

Sử dụng Closures

Thay vì sử dụng các lớp sự kiện tùy chỉnh, bạn có thể đăng ký các lần đóng để thực thi khi các sự kiện mô hình khác nhau được gửi đi. Thông thường, bạn nên đăng ký các bao đóng này trong phương thức

php artisan make:model Post -all
645 của mô hình của mình

php artisan make:migration update_name_column_in_contacts_table
72

Nếu cần, bạn có thể sử dụng trình xử lý sự kiện ẩn danh có thể xếp hàng đợi khi đăng ký sự kiện mô hình. Điều này sẽ hướng dẫn Laravel thực thi trình lắng nghe sự kiện mô hình trong nền bằng cách sử dụng hàng đợi của ứng dụng của bạn

php artisan make:migration update_name_column_in_contacts_table
73

quan sát viên

Xác định người quan sát

Nếu bạn đang lắng nghe nhiều sự kiện trên một mô hình nhất định, bạn có thể sử dụng bộ quan sát để nhóm tất cả người nghe của mình vào một lớp duy nhất. Các lớp Người quan sát có các tên phương thức phản ánh các sự kiện Eloquent mà bạn muốn lắng nghe. Mỗi phương thức này nhận mô hình bị ảnh hưởng làm đối số duy nhất của chúng. Lệnh

php artisan make:model Post -all
697 Artisan là cách dễ nhất để tạo một lớp quan sát viên mới

php artisan make:migration update_name_column_in_contacts_table
74

Lệnh này sẽ đặt người quan sát mới vào thư mục

php artisan make:model Post -all
698 của bạn. Nếu thư mục này không tồn tại, Artisan sẽ tạo nó cho bạn. Người quan sát mới của bạn sẽ giống như sau

php artisan make:migration update_name_column_in_contacts_table
75

Để đăng ký một người quan sát, bạn cần gọi phương thức

php artisan make:model Post -all
699 trên mô hình mà bạn muốn quan sát. Bạn có thể đăng ký người quan sát theo phương pháp

php artisan make:model Flight --migration

39 của nhà cung cấp dịch vụ
php artisan make:model Post -all
901 của ứng dụng của bạn

php artisan make:migration update_name_column_in_contacts_table
76

Ngoài ra, bạn có thể liệt kê các quan sát viên của mình trong một thuộc tính

php artisan make:model Post -all
902 của lớp
php artisan make:model Post -all
901 của ứng dụng của bạn

php artisan make:migration update_name_column_in_contacts_table
77

Lưu ý
Có những sự kiện bổ sung mà người quan sát có thể nghe, chẳng hạn như

php artisan make:model Post -all
435 và
php artisan make:model Post -all
667. Những sự kiện này được mô tả trong tài liệu sự kiện.

Người quan sát & Giao dịch cơ sở dữ liệu

Khi các mô hình đang được tạo trong một giao dịch cơ sở dữ liệu, bạn có thể muốn hướng dẫn một người quan sát chỉ thực hiện các trình xử lý sự kiện của nó sau khi giao dịch cơ sở dữ liệu được thực hiện. Bạn có thể thực hiện điều này bằng cách xác định một thuộc tính

php artisan make:model Post -all
906 trên người quan sát. Nếu một giao dịch cơ sở dữ liệu không được tiến hành, các trình xử lý sự kiện sẽ thực thi ngay lập tức

php artisan make:migration update_name_column_in_contacts_table
78

Sự kiện tắt tiếng

Đôi khi, bạn có thể cần tạm thời "tắt tiếng" tất cả các sự kiện được kích hoạt bởi một mô hình. Bạn có thể đạt được điều này bằng cách sử dụng phương pháp

php artisan make:model Post -all
907. Phương thức
php artisan make:model Post -all
907 chấp nhận một bao đóng làm đối số duy nhất của nó. Bất kỳ mã nào được thực thi trong lần đóng này sẽ không gửi các sự kiện mô hình và mọi giá trị được trả về bởi lần đóng sẽ được trả về bằng phương thức
php artisan make:model Post -all
907

php artisan make:migration update_name_column_in_contacts_table
79

Lưu một mô hình duy nhất mà không có sự kiện

Đôi khi bạn có thể muốn "lưu" một mô hình nhất định mà không gửi bất kỳ sự kiện nào. Bạn có thể thực hiện việc này bằng cách sử dụng phương pháp

php artisan make:model Post -all
910

php artisan make:model Flight --migration

00

Bạn cũng có thể "cập nhật", "xóa", "xóa mềm", "khôi phục" và "sao chép" một mô hình nhất định mà không gửi bất kỳ sự kiện nào

Làm cách nào để tạo di chuyển trong Laravel bằng cmd?

Để tạo một lần di chuyển mới, bạn có thể chạy make. migration Lệnh Artisan và lệnh đó sẽ khởi động một lớp mới trên ứng dụng Laravel của bạn, trong thư mục cơ sở dữ liệu/di chuyển. Lớp này sẽ chứa mã soạn sẵn mặc định.

Làm cách nào để tạo một mô hình trong Laravel?

Bạn có thể sử dụng đồ thủ công. trình trợ giúp dòng lệnh mô hình để tạo các mô hình mới cho ứng dụng của bạn . Để tạo một mô hình Eloquent mới cho bảng liên kết của bạn, hãy chạy. docker-compose exec app php artisan make. Liên kết mô hình.

Lệnh di chuyển trong Laravel là gì?

Di chuyển giống như kiểm soát phiên bản cho cơ sở dữ liệu của bạn, cho phép nhóm của bạn sửa đổi và chia sẻ lược đồ cơ sở dữ liệu của ứng dụng . Di chuyển thường được ghép nối với trình tạo lược đồ của Laravel để xây dựng lược đồ cơ sở dữ liệu của ứng dụng của bạn.

Làm cách nào để tạo bộ điều khiển mô hình và di chuyển trong Laravel 9?

Các cờ có sẵn để Tạo mô hình trong laravel. .
-c, –controller Để tạo bộ điều khiển mới cho mô hình
-f, –factory Để tạo nhà máy mới cho mô hình
–force Để tạo lớp ngay cả khi mô hình tồn tại
-m, –migration Để tạo chuyển đổi cho mô hình
-s, –seed Để tạo tệp seeder cho mô hình

Chủ Đề