دستورات مفید مربوط به migration در لاارول
احسان

نویسنده

  • 1399/10/5
  • 0
  • 35
3 سال پیش| برنامه‌نویسی وب

دستورات مفید مربوط به migration در لاارول

دستورات مفید مربوط به migration در لاارول
php artisan migrate

این دستور برای اجرای تمام مایگریشن‌های اجرا نشده کاربر دارد.

php artisan make:migration create_posts_table

دستور بالا می‌گوید که یک جدول با نام posts ایجاد شود.

php artisan migrate:rollback

در صورتی که به هر دلیل قصد داشته باشیم یک مرحله به عقب برگردیم، از دستور rollback استفاده می‌کنیم.

php artisan migrate:rollback --step=2

اگر قصد داشته باشیم بیش از یک مرحله به قبل برگردیم، با استفاده از سوئیچ step، تعداد مراحل مورد نظر را مشخص و به همان تعداد rollback انجام می‌دهیم.

php artisan make:migration add_user_id_to_posts

در مثال بالا فرض بر این است جدولی ایجاد کرده و قصد داریم یک فیلد به آن اضافه کنیم تا اطلاعات موجود در جدول از بین نرود. در این حالت می‌توانیم از دستوری مشابه دستور فوق استفاده کنیم. دستور بالا می‌گوید که به جدول posts یک فیلد به نام user_id اضافه کن.

حالا فرض می‌گیریم که فیلد user_id افزوده و مایگریشن نظیر آن نیز ایجاد شده است. به صورت پیش‌فرض این فیلد در انتهای سایر فیلدها قرار خواهد گرفت. اما اگر قصد داشته باشیم جایگاه آن مشخص شود، به صورت زیر عمل می‌کنیم و در فایل مایگریشن مربوطه کد زیر را می‌نویسیم. یعنی فیلد user_id را بعد از فیلد id ایجاد کن.

$table->integer('user_id')->after('id');

در نهایت نیز برای ایجاد فیلد (فیلدهای) جدید یا به عبارتی تغییرات جدید، کافی است دستور زیر را اجرا کنیم:

php artisan migrate

اما چطور کلید خارجی یا همان foreign key ایجاد کنیم؟ پاسخ ساده است. به صورت زیر:

$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

کد بالا می‌گوید که یک فیلد با عنوان user_id که کلید خارجی برای id از جدول users است ایجاد کن و در صورتی که کلید اصلی که همان id است به هر دلیلی حذف شد، رکوردهای دارای user_id متناظر را نیز حذف کن.

 

به‌روز رسانی: 1403/8/2
توی وبسایتم سعی می‌کنم محتوایی که تصور کنم ارزشمنده و به بقیه کمکی می‌کنه رو منتشر کنم. امیدوارم از مطالب وبسایت بتونید استفاده کنید و به کارتون بیاد. در ضمن اگه پروژه‌ی تحت وبی دارید که نیاز به برنامه‌نویسی و اجرا داره، می‌تونید با شماره انتهای صفحه با من تماس بگیرید تا در موردش با هم صحبت کنیم.
برچسب‌ها:


دیدگاه کاربران

ثبت دیدگاه

آدرس ایمیل شما منتشر نخواهد شد. فیلدهای الزامی مشخص شده اند*