آموزش استفاده از modifyCollate() در Laravel 11

laravel 11 modify collate
22 اردیبهشت 1404

مقدمه‌ای درباره Laravel و SqlServerGrammar


Laravel یکی از پرطرفدارترین فریمورک‌های PHP است که به خاطر سادگی و قدرتش در توسعه وب اپلیکیشن‌ها شناخته می‌شود. یکی از اجزای مهم در Laravel، کلاسی به نام SqlServerGrammar است. این کلاس وظیفه مدیریت ساختار SQL را بر عهده دارد و به ما کمک می‌کند که با پایگاه داده‌های مختلف ارتباط برقرار کنیم.


یکی از ویژگی‌های برجسته SqlServerGrammar، متد modifyCollate() است. این متد به ما این امکان را می‌دهد که نحوه مقایسه داده‌ها در پایگاه داده SQL Server را تغییر دهیم. به طور معمول، در یک پایگاه داده، نوع مقایسه بین رشته‌ها (مثلاً بزرگ و کوچک بودن حروف) بر اساس تنظیمات منطقه‌ای (collation) تعیین می‌شود.


در Laravel 11، استفاده از این متد به ما کمک می‌کند که با توجه به نیازهای خاص پروژه‌مان، تنظیمات مقایسه را دقیق‌تر کنترل کنیم. به عنوان مثال، ما می‌توانیم نوع collation را برای یک ستون خاص تغییر دهیم تا مقادیر در آن به شیوه‌ای خاص مقایسه شوند.


در این مطلب، قصد داریم تا به معرفی این متد و نحوه استفاده از آن بپردازیم. همچنین کدهایی را ارائه می‌دهیم که نشان می‌دهد چگونه می‌توان از متد modifyCollate() در پروژه‌های واقعی استفاده کرد.


کد مثال برای استفاده از modifyCollate()


use Illuminate\Database\Schema; 
use Illuminate\Database\Migrations\Migration;

class UpdateTableExample extends Migration {
public function up() {
Schema::table('examples', function (Blueprint $table) {
$table->string('name')->collate('utf8_general_ci')->change();
});
}

public function down() {
Schema::table('examples', function (Blueprint $table) {
$table->string('name')->collate('utf8_unicode_ci')->change();
});
}
}

توضیحات کد


در اینجا به توضیح کد ارائه شده می‌پردازیم:




use Illuminate\Database\Schema;

این خط کد، کلاس Schema از لاراول را برای استفاده از توابع مربوط به پایگاه داده وارد می‌کند.



use Illuminate\Database\Migrations\Migration;

این خط کد همچنین کلاس Migration را وارد می‌کند، که برای مدیریت تغییرات در پایگاه داده استفاده می‌شود.



class UpdateTableExample extends Migration {

در اینجا یک کلاس جدید به نام UpdateTableExample تعریف می‌شود که از کلاس Migration ارث‌بری می‌کند.



public function up() {

این متد به نام up() است که معمولاً برای اعمال تغییرات در پایگاه داده استفاده می‌شود.



Schema::table('examples', function (Blueprint $table) {

در این خط، ما به جدول examples در پایگاه داده دسترسی پیدا می‌کنیم و تغییراتی را روی آن اعمال می‌کنیم.



$table->string('name')->collate('utf8_general_ci')->change();

در اینجا ما نوع collation ستون name را به utf8_general_ci تغییر می‌دهیم، که نوع مقایسه‌ای است که به ما اجازه می‌دهد مقادیر را به شیوه‌ای خاص مقایسه کنیم.



public function down() {

این متد برای برگرداندن تغییرات ایجاد شده در متد up() استفاده می‌شود.



$table->string('name')->collate('utf8_unicode_ci')->change();

در اینجا، ما collation ستون name را به نوع اولیه آن برمی‌گردانیم، یعنی utf8_unicode_ci.

سوالات متداول

؟

متد modifyCollate در Laravel چه‌کاری انجام می‌دهد؟

؟

چگونه می‌توان از متد modifyCollate در پروژه‌های خود استفاده کرد؟

؟

آیا تغییر collation برای همه ستون‌ها ممکن است؟

؟

متد down در Migration چیست؟

؟

چگونه می‌توان تغییرات را در پایگاه داده اعمال کرد؟