Trong quá trình làm việc mình đã gặp nhiều trường hợp cập nhật lại dữ liệu cho 1 table bằng cách sử dụng seeder. Vậy làm thế nào để chúng ta có thể thêm các tham số tùy chỉnh khi chạy seeder?.
1. Truyền tham số trực tiếp trong command khi chạy
1.1 Sử dụng command->ask('key')
Trong file seeder hãy sử dụng phương thức ask('SEED_KEY', 'default_value')
, lệnh này sẽ yêu cầu nhập giá trị khi chạy seeder nếu bạn để trống và enter giá trị SEED_KEY
sẽ là default_value
.
// database/seeders/UpdateSomeThingSeeder.php
class UpdateSomeThingSeeder extends Seeder
{
public function run()
{
$valueName = $this->command->ask('SEED_KEY', 'Thanh');
$this->command->alert("User name: {$userName}");
}
}
Chạy thử seeder
php artisan db:seed --class=UpdateSomeThingSeeder
Đây là kết quả khi sau khi chạy seeder
$php artisan db:seed --class=UpdateSomeThingSeeder
User name [Thanh]:
> Cong Thanh
*********************************
* User name: Cong Thanh *
*********************************
Database seeding completed successfully.
1.2 Sử dụng env('key')
Trong file seeder hãy sử dụng env('SEED_KEY', 'default_value')
, lệnh này sẽ lấy giá trị biến SEED_KEY
trong file cấu hình .env
hoặc bạn cũng có thể truyền trực tiếp khi chạy seeder
// database/seeders/UpdateSomeThingSeeder.php
class UpdateSomeThingSeeder extends Seeder
{
public function run()
{
$valueName = env('SEED_KEY', 'Thanh');
$this->command->alert("User name: {$userName}");
}
}
Chạy thử seeder
SEED_KEY='Cong Thanh' php artisan db:seed --class=UpdateSomeThingSeeder
Đây là kết quả khi chạy seeder
$SEED_KEY='Cong Thanh' php artisan db:seed --class=UpdateSomeThingSeeder
*********************************
* User name: Cong Thanh *
*********************************
Database seeding completed successfully.
2. Truyền tham số giữa các seeder
Trong file seeder hãy sử dụng callWith(seederClass, params = [])
hàm này có 2 tham số:
- seederClass: giống với hàm
call()
tham số này chính làClass
của seeder bạn muốn chạy - params: các biến bạn muốn truyền sang cho seeder
seederClass
khi chạy
// database/seeders/DatabaseSeeder.php
class DatabaseSeeder extends Seeder
{
public function run()
{
$this->callWith(UpdateSomeThingSeeder::class, ['userName' => 'Cong Thanh']);
}
}
// database/seeders/UpdateSomeThingSeeder.php
class UpdateSomeThingSeeder extends Seeder
{
public function run($userName = 'Thanh')
{
$this->command->alert("User name: {$userName}");
}
}
Chạy thử seeder
php artisan db:seed
Đây là kết quả khi chạy seeder
php artisan db:seed
Seeding: DatabaseSeedersUpdateSomeThingSeeder
*********************************
* User name: Cong Thanh *
*********************************
Seeded: DatabaseSeedersUpdateSomeThingSeeder (0.35ms)
Database seeding completed successfully.
3. Tham khảo
- Laravel – Seeder
- Laravel – Command ask()
- Youtube – Laravel Daily
4. Lời kết
Hi vọng chia sẻ này sẽ giúp các bạn newbie 1 phần nào trong quá trình tìm hiểu về Laravel. Nếu thấy hữu ích hãy cho mình 1 vote 👍 để thêm nhiều người biết đến chia sẻ này nhé.
Mình là Công Thành cám ơn các bạn đa theo dõi bài viết của mình, nếu có câu hỏi nào vui lòng bình luận phía dưới 👇 nhé.
Xem thêm series bài viết 👉 Laravel tips
Bài viết liên quan
[CSF-2] Một số thiết lập CSF, LFD
Hôm nay mình sẽ thực hiện một số thiết lập trên CSF Mở file config để sửa đổi một số tính năng dưới /etc/csf/csf.conf Nội dung chính1. Truyền tham số trực tiếp trong command khi...
[CSF-1] Tăng bảo mật Server với ConfigServer Firewall (CSF)
Nội dung chính1. Truyền tham số trực tiếp trong command khi chạy1.1 Sử dụng command->ask('key')1.2 Sử dụng env('key')2. Truyền tham số giữa các seeder3. Tham khảo4. Lời kết1. Khái niệm CSF: CSF (ConfigServer & Firewall)...
Sử dụng SSH Key với Gitlab và Github
Bài viết này mình sẽ hướng dẫn các bạn tạo ssh key cho Gitlab và Github SSH là gì? Secure Socket Shell là một giao thức mạng dùng để thiết lập kết nối mạng một...
Directory traversal vulnerabilities (phần 4)
Nội dung chính1. Truyền tham số trực tiếp trong command khi chạy1.1 Sử dụng command->ask('key')1.2 Sử dụng env('key')2. Truyền tham số giữa các seeder3. Tham khảo4. Lời kếtV. Phân tích và khai thác các lỗ...
Directory traversal vulnerabilities (phần 3)
Nội dung chính1. Truyền tham số trực tiếp trong command khi chạy1.1 Sử dụng command->ask('key')1.2 Sử dụng env('key')2. Truyền tham số giữa các seeder3. Tham khảo4. Lời kếtV. Phân tích và khai thác các lỗ...
Directory traversal vulnerabilities (phần 2)
Nội dung chính1. Truyền tham số trực tiếp trong command khi chạy1.1 Sử dụng command->ask('key')1.2 Sử dụng env('key')2. Truyền tham số giữa các seeder3. Tham khảo4. Lời kếtIII. Vì sao lỗ hổng Directory traversal xuất...