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ình01 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.
php artisan make:model Flight --migration
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ớiphp artisan make:model Post -all0
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
06php 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 -all4
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ìnhphp artisan make:model Post -all6
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 Eloquentphp artisan make:model Post -all9
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
14Nế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ìnhpublic function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
6Khó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ìnhpublic function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
9Ngoà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
19php artisan make:migration update_name_column_in_contacts_table
2Nế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
21php artisan make:migration update_name_column_in_contacts_table
5Khó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 UUIDphp artisan make:migration update_name_column_in_contacts_table
7Theo 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ểnBạ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ìnhphp artisan make:model Flight --migration
0Nế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 ULIDphp artisan make:model Flight --migration
1Dấ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
19php artisan make:model Flight --migration
2Nế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 JSONphp artisan make:model Flight --migration
3Nế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ìnhphp artisan make:model Flight --migration
4Nế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
35php artisan make:model Flight --migration
5kế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ìnhphp artisan make:model Flight --migration
6Giá 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ìnhphp artisan make:model Flight --migration
7Cấ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
40php artisan make:model Flight --migration
8Ngoà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ìnhphp artisan make:model Flight --migration
9Cuố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 Eloquentphp artisan make:model Post -all40
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
44php artisan make:model Post -all41
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ìnhphp artisan make:model Post -all42
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 -all43
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ưởngphp artisan make:model Post -all44
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ớiphp artisan make:model Post -all45
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ọiphp artisan make:model Post -all46
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 -all47
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ơnPhươ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ìnhphp artisan make:model Post -all48
Đố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 đóngNế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ướcphp artisan make:model Post -all49
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ấtphp artisan make:model Post -all60
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ướcphp artisan make:model Post -all61
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
78con 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 EloquentPhươ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ức80 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ế.
php artisan make:model Flight --migration
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àyphp artisan make:model Post -all62
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ểmphp artisan make:model Post -all63
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 đíchSử 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ấtphp artisan make:model Post -all64
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ệuphp artisan make:model Post -all65
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ấtphp artisan make:model Post -all66
Đô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 -all400 và
php artisan make:model Post -all401 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 -all67
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 -all402 và
php artisan make:model Post -all403 sẽ lấy kết quả đầu tiên của truy vấn;
php artisan make:model Post -all68
Nếu không bắt được
php artisan make:model Post -all405, phản hồi HTTP 404 sẽ tự động được gửi lại cho máy khách
php artisan make:model Post -all69
Truy xuất hoặc tạo mô hình
Phương thức
php artisan make:model Post -all406 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 -all407, giống như
php artisan make:model Post -all406, 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 -all407 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 -all410 để duy trì nó
php artisan make:model Post -all90
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 -all411,
php artisan make:model Post -all412,
php artisan make:model Post -all413 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 -all91
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 -all410 trên phiên bản mô hình
php artisan make:model Post -all92
Trong ví dụ này, chúng tôi chỉ định trường
php artisan make:model Post -all415 từ yêu cầu HTTP đến cho thuộc tính
php artisan make:model Post -all415 của phiên bản mô hình
php artisan make:model Post -all417. Khi chúng ta gọi phương thức
php artisan make:model Post -all410, 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 -all410 đượ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 -all422 để "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 -all422
php artisan make:model Post -all93
Tuy nhiên, trước khi sử dụng phương thức
php artisan make:model Post -all422, bạn cần chỉ định thuộc tính
php artisan make:model Flight --migration
42 hoặc php artisan make:model Post -all426 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 -all410 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 -all410 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ôngphp artisan make:model Post -all94
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 -all95
Phương thức
php artisan make:model Post -all433 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 -all433 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ìnhphp artisan make:model Post -all435,php artisan make:model Post -all436,php artisan make:model Post -all437 vàphp artisan make:model Post -all438 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 -all439,
php artisan make:model Post -all440 và
php artisan make:model Post -all441 để 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 -all439 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 -all439 để xác định xem có thuộc tính nào "bẩn" không. Phương thức
php artisan make:model Post -all440 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 -all96
Phương thức
php artisan make:model Post -all441 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 -all97
Phương thức
php artisan make:model Post -all446 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 -all98
chuyển nhượng hàng loạt
Bạn có thể sử dụng phương thức
php artisan make:model Post -all422 để "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 -all93
Tuy nhiên, trước khi sử dụng phương thức
php artisan make:model Post -all422, bạn cần chỉ định thuộc tính
php artisan make:model Flight --migration
42 hoặc php artisan make:model Post -all426 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 -all451 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 -all422 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 -all453 trên mô hình. Ví dụ: hãy đặt thuộc tính
php artisan make:model Post -all415 của mô hình
php artisan make:model Flight --migration
10 có thể gán khối lượngpublic function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
60Khi 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 -all422 để chèn bản ghi mới vào cơ sở dữ liệu. Phương thức
php artisan make:model Post -all422 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[];
}];
}
61Nế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 -all458 để đ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[];
}];
}
62Chuyể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 -all453 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 -all426
public function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
63Cho 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 -all461 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 -all458,
php artisan make:model Post -all422 và
php artisan make:model Post -all433 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[];
}];
}
64Ngoạ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 -all453 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ạnpublic function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
65Upserts
Đô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 -all406, phương thức
php artisan make:model Post -all469 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 -all410 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 -all471 của
php artisan make:model Post -all472 và vị trí
php artisan make:model Post -all431 của
php artisan make:model Post -all432, các cột
php artisan make:model Post -all475 và
php artisan make:model Post -all476 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[];
}];
}
66Nế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 -all477 để 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 -all477 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ìnhpublic function up[]
{
Schema::create['contacts', function [Blueprint $table]
{
$table->id[];
$table->string['name'];
$table->string['mobile_no'];
$table->boolean['status'];
$table->timestamps[];
}];
}
67Cả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ứcphp artisan make:model Post -all477 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ứcphp artisan make:model Post -all477 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 -all483 trên phiên bản mô hình
Bạn có thể gọi phương thức
php artisan make:model Post -all484 để 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 -all484 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 -all483. 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 -all487. 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 -all487 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[];
}];
}
68Cảnh báo
Phương thứcphp artisan make:model Post -all487 tải từng mô hình riêng lẻ và gọi phương thứcphp artisan make:model Post -all483 để các sự kiệnphp artisan make:model Post -all491 vàphp artisan make:model Post -all492 đượ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[];
}];
}
69Cả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ìnhphp artisan make:model Post -all491 vàphp artisan make:model Post -all492 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 -all495 đượ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 -all496 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[];
}];
}
90Lưu ý
Đặc điểmphp artisan make:model Post -all497 sẽ tự động chuyển thuộc tínhphp artisan make:model Post -all495 thành phiên bảnphp artisan make:model Post -all499 /php artisan make:model Post -all600 cho bạn.
Bạn cũng nên thêm cột
php artisan make:model Post -all495 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[];
}];
}
91Bây giờ, khi bạn gọi phương thức
php artisan make:model Post -all483 trên model, cột
php artisan make:model Post -all495 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 -all604
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 -all605 trên một phiên bản mô hình. Phương pháp
php artisan make:model Post -all605 sẽ đặt cột
php artisan make:model Post -all495 của mô hình thành
php artisan make:model Post -all608
Bạn cũng có thể sử dụng phương pháp
php artisan make:model Post -all605 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 -all605 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[];
}];
}
92Xó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 -all611 để 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 -all611 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[];
}];
}
93Truy 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 -all613 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[];
}];
}
94Phương thức
php artisan make:model Post -all613 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[];
}];
}
95Chỉ truy xuất các mô hình đã xóa mềm
Phương pháp
php artisan make:model Post -all615 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[];
}];
}
96Mô 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 -all616 hoặc
php artisan make:model Post -all617 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 -all618 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[];
}];
}
97Khi đánh dấu các mô hình là
php artisan make:model Post -all619, bạn cũng có thể xác định một phương pháp
php artisan make:model Post -all620 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[];
}];
}
98Sau 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 -all621 trong lớp
php artisan make:model Post -all622 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 -all621 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 -all625 để chỉ định tên lớp mô hình
php artisan make:migration update_name_column_in_contacts_table
20Nế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 -all626
php artisan make:migration update_name_column_in_contacts_table
21Bạn có thể kiểm tra truy vấn
php artisan make:model Post -all618 của mình bằng cách thực hiện lệnh
php artisan make:model Post -all621 với tùy chọn
php artisan make:model Post -all629. Khi giả vờ, lệnh
php artisan make:model Post -all621 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
22Cả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 -all611] 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 -all617, 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 -all620 sẽ không được gọi, cũng như các sự kiện mô hình
php artisan make:model Post -all491 và
php artisan make:model Post -all492 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
23Sao 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 -all636. 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 -all636
php artisan make:migration update_name_column_in_contacts_table
25Phạ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 -all638. 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 -all639 yêu cầu bạn triển khai một phương thức.
php artisan make:model Post -all640. Phương pháp
php artisan make:model Post -all640 có thể thêm các ràng buộc
php artisan make:model Post -all642 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
26Lư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ức94 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.
php artisan make:model Flight --migration
Á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 -all645 của mô hình và gọi phương thức
php artisan make:model Post -all646 của mô hình. Phương thức
php artisan make:model Post -all646 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
27Sau khi thêm phạm vi trong ví dụ trên vào mô hình
php artisan make:model Post -all648, lệnh gọi phương thức
php artisan make:model Post -all649 sẽ thực thi truy vấn SQL sau
php artisan make:migration update_name_column_in_contacts_table
28Phạ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 -all646
php artisan make:migration update_name_column_in_contacts_table
29Loạ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 -all651. 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
50Hoặ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
51Nế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 -all652
php artisan make:migration update_name_column_in_contacts_table
52Phạ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 -all653
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 -all654
php artisan make:migration update_name_column_in_contacts_table
53Sử 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 -all653 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
54Kế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 -all656 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
55Tuy 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 -all657 "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
56Phạ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 -all658
php artisan make:migration update_name_column_in_contacts_table
57Khi 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
58So 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 -all659 và
php artisan make:model Post -all660 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
59Các phương thức
php artisan make:model Post -all659 và
php artisan make:model Post -all660 cũng khả dụng khi sử dụng các mối quan hệ
php artisan make:model Post -all663,
php artisan make:model Post -all664,
php artisan make:model Post -all665 và
php artisan make:model Post -all666. 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
70Sự 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 -all667,
php artisan make:model Post -all668,
php artisan make:model Post -all669,
php artisan make:model Post -all437,
php artisan make:model Post -all438,
php artisan make:model Post -all435,
php artisan make:model Post -all436,
php artisan make:model Post -all491,
php artisan make:model Post -all492,
php artisan make:model Post -all604,
php artisan make:model Post -all677,
php artisan make:model Post -all678,
php artisan make:model Post -all679, và
php artisan make:model Post -all680
Sự kiện
php artisan make:model Post -all667 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 -all668 và
php artisan make:model Post -all669 sẽ gửi đi. Các sự kiện
php artisan make:model Post -all437 /
php artisan make:model Post -all438 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 -all410 được gọi. Các sự kiện
php artisan make:model Post -all435 /
php artisan make:model Post -all436 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 -all689 đượ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 -all690 đượ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 -all691 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
71Sau 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ìnhphp artisan make:model Post -all436,php artisan make:model Post -all438,php artisan make:model Post -all491 vàphp artisan make:model Post -all492 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 -all645 của mô hình của mình
php artisan make:migration update_name_column_in_contacts_table
72Nế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
73quan 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 -all697 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
74Lệnh này sẽ đặt người quan sát mới vào thư mục
php artisan make:model Post -all698 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 -all699 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 -all901 của ứng dụng của bạn
php artisan make:migration update_name_column_in_contacts_table
76Ngoà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 -all902 của lớp
php artisan make:model Post -all901 của ứng dụng của bạn
php artisan make:migration update_name_column_in_contacts_table
77Lư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 -all435 vàphp artisan make:model Post -all667. 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 -all906 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
78Sự 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 -all907. Phương thức
php artisan make:model Post -all907 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 -all907
php artisan make:migration update_name_column_in_contacts_table
79Lư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 -all910
php artisan make:model Flight --migration
00Bạ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