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 Show
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 laravelCá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 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. 6, chúng ta nên chạy lệnh như
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ộtCô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 7, Đặt cột 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.
Trại khởi động LaravelNế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 02 và mở rộng lớp 03. Bạn có thể sử dụng lệnh Artisan 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 05 hoặc 06
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 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ồnCác mô hình được tạo bởi lệnh 04 sẽ được đặt trong thư mục 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ảngSau 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 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 10 lưu trữ các bản ghi trong bảng 12, trong khi mô hình 13 sẽ lưu trữ các bản ghi trong bảng 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 15 trên mô hình 6Khóa chínhEloquent 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à 16. Nếu cần, bạn có thể xác định thuộc tính 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 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 18 công khai trên mô hình của mình được đặt thành 19 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 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à 21 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 & ULIDThay 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 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 7Theo mặc định, Đặc điểm 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 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 25 trên mô hình 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 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 1Dấu thời gianTheo mặc định, Eloquent mong đợi các cột 27 và 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 29 trên mô hình của mình với giá trị là 19 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 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 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ố 32 và 33 trên mô hình của mình 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 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 35 5kết nối cơ sở dữ liệuTheo 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 36 trên mô hình 6Giá trị thuộc tính mặc địnhTheo 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 37 trên mô hình của mình 7Cấu hình Eloquent StrictnessLaravel 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 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 39 của ứng dụng của bạn 40 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 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 42 của mô hình 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 đề 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 44php artisan make:model Post -all41 Truy xuất mô hìnhKhi 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 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 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 47 để truy xuất kết quảphp artisan make:model Post -all43
Làm mới người mẫuNế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 48 và 49. Phương thức 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 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ậpNhư chúng ta đã thấy, các phương thức Eloquent như 45 và 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 54 được trả vềLớp Eloquent 55 mở rộng lớp cơ sở 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 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 45 hoặc 47. Thay vì sử dụng các phương pháp này, phương pháp 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 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 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 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 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 65. Sử dụng phương pháp 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 65 sẽ luôn truy xuất các mô hình có cột 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 CollectionsPhương thức 69 hoạt động tương tự như phương thức 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 69 trả về một 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 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 74. Bên trong, phương thức 74 sẽ luôn truy xuất các mô hình có cột 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 16 bằng phương pháp 78con trỏTương tự như phương pháp 69, phương pháp 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 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ỏ
Bên trong, phương thức 80 sử dụng trình tạo PHP để triển khai chức năng nàyphp artisan make:model Post -all62 80 trả về một phiên bản 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 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 69 để thay thếTruy vấn con nâng caoLựa chọn truy vấn conEloquent 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 89 và một bảng 12 đến các điểm đến. Bảng 12 chứa cột 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 43 và 94 của trình tạo truy vấn, chúng tôi có thể chọn tất cả 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 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ợpNgoà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 97, 98 hoặc 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ìnhPhươ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ợpKhi 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ìnhphụ trangTấ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 27 và 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 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ậtPhươ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 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ạtCậ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
Kiểm tra thay đổi thuộc tínhEloquent 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ạtBạ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 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 10 có thể gán khối lượng 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 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 62Chuyển nhượng hàng loạt & cột JSONKhi 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 63Cho phép chuyển nhượng hàng loạtNế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 64Ngoại lệ chuyển nhượng hàng loạtTheo 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 41. Thông thường, phương thức này nên được gọi trong phương thức 39 của một trong những nhà cung cấp dịch vụ của ứng dụng của bạn 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 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 27 và 28 nếu dấu thời gian được bật trên mô hình 67
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 68
Xóa mô hình bằng truy vấnTấ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 69
Xóa mềmNgoà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 90
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 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ệ 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 93Truy vấn các mô hình đã xóa mềmBao gồm cả các mô hình đã xóa mềmNhư đã 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 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ệ 95Chỉ truy xuất các mô hình đã xóa mềmPhương pháp php artisan make:model Post -all615 sẽ chỉ truy xuất các mô hình đã xóa mềm 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 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 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 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 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 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 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 22
cắt tỉa hàng loạtKhi 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 23Sao chép mô hìnhBạ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 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 25Phạm vi truy vấnPhạm vi toàn cầuPhạ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ầuViế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 26
Á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ó 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 28Phạm vi toàn cầu ẩn danhEloquent 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 29Loại bỏ phạm vi toàn cầuNế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ó 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 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 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 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 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 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 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 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 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 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 đó 70Sự kiện
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ó 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
Sử dụng ClosuresThay 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 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 73quan sát viênXác định người quan sátNế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 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 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 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 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 77
Người quan sát & Giao dịch cơ sở dữ liệuKhi 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 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 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 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 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 |