Bezpečná změna typů sloupců v Laravelu pomocí migrací

Jak změnit typy sloupců pomocí migrací Laravel Někdy je třeba změnit datový typ sloupce ve vaší databázi. Například chcete změnit sloupec ze sloupce string to integernebo z text t...

Světlý režim slouží jen pro ukázku funkcionality. Proto používejte tmavou verzi webu.

01. 08. 2025

Bezpečná změna typů sloupců v Laravelu pomocí migrací

Jak změnit typy sloupců pomocí migrací Laravel

Někdy je třeba změnit datový typ sloupce ve vaší databázi. Například chcete změnit sloupec ze sloupce string to integernebo z text to boolean. Laravel to umožňuje pomocí migrace.

V tomto příspěvku vás provedeme jednotlivými kroky.

Krok 1: (volitelně) Nainstalujte doctrine/dbal Balíček

Počínaje Laravel 10, již není nutné instalovat doctrine/dbal balíček pro většinu úprav sloupců. Pokud však vaše aplikace používá Laravel 10 aSQLite databázi, je třeba ji ještě nainstalovat, aby bylo možné měnit sloupce.

Pokud používáte SQLite, spusťte tento příkaz:

composer require doctrine/dbal

Krok 2: Vytvoření nové migrace

K vytvoření nového migračního souboru použijte příkaz Artisan:

php artisan make:migration change_column_type_in_users_table

Tím se vytvoří soubor v adresáři database/migrations složka.

Krok 3: Úprava sloupce

Otevřete nový migrační soubor. Uvnitř up() použijte metodu change() na sloupci. V tomto příkladu měníme age sloupec z string to integer:

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
 
return new class extends Migration {
public function up(): void
{
Schema::table('users', function (Blueprint $table) {
$table->integer('age')->change();
});
}
 
public function down(): void
{
Schema::table('users', function (Blueprint $table) {
$table->string('age')->change();
});
}
};

Důležité úvahy

  • Zkontrolujte, zda sloupec existuje: Zkontrolujte, zda je název sloupce správný a zda již v tabulce existuje.
  • ⚠️ Kontrola kompatibility dat: Ujistěte se, že stávající data ve sloupci lze bezpečně převést na nový typ. V opačném případě databáze vyhodí chybu.
  • 🔔 Opětovná definice všech modifikátorů: Od verze Laravel 10 musíte při úpravě sloupce výslovně uvést všechny modifikátory sloupce, které chcete zachovat (jako např. nullable(), default(), nebo unsigned()). Chybějící modifikátory budou vyřazeny.

Krok 4: Spuštění migrace

Nyní použijte migraci:

php artisan migrate

Souhrn

  • Instalace doctrine/dbal pouze v případě potřeby (např. Laravel 9 a starší verze nebo SQLite v Laravel 10).
  • Vytvoření migrace
  • Použijte $table->type('column')->change()
  • Dávejte pozor, abyste znovu zahrnuli modifikátory jako např. nullable()
  • Spustit php artisan migrate

Takto lze bezpečně aktualizovat typy sloupců v systému Laravel.

Původní článek publikoval Nabil Hassen.

Mohlo by vám pomoct

Praktické věci kolem webu

Než se pustíte do webu, hodí se mít jasno v podkladech, WordPressu, cookies a měření.

Google reference

Co říkají klienti

Ukázky skutečných recenzí, které klienti zanechali na mém Google profilu.

Přejít na recenze
★ ★ ★ ★ ★

„Člověk, který své práci a rozumí a ví co dělá. Velmi rychlá komunikace a profesionální přístup. Doporučuji.“

Jaroslav Kupča
Google
★ ★ ★ ★ ★

„Skvělá spolupráce, při dalších projektech určitě nebudu shánět někoho jiného.“

Roman Koňařík
Google
★ ★ ★ ★ ★

„S panem Vančurou jsem spolupracovala na tvorbě mých webových stránek a jsem maximálně spokojená. Oceňuji profesionální přístup, rychlou komunikaci a schopnost přesně pochopit moje představy. Web je moderní, přehledný, funkční a skvěle vypadá i na mobilu. Celý proces proběhl hladce, s jasným vysvětlením jednotlivých kroků a výborným výsledkem. Určitě doporučuji každému, kdo hledá spolehlivý a kvalitní přístup.“

Barbora Zemánková
Google
★ ★ ★ ★ ★

„Spolupráce při tvorbě konfigurátoru proběhla naprosto bez problémů. Oceňuji profesionální přístup, rychlou komunikaci a schopnost pochopit specifický projekt od A do Z. Konfigurátor je přehledný, funkční a přesně odpovídá mým požadavkům. Rozhodně doporučuji.“

mareksevcik_FPV
Google
★ ★ ★ ★ ★

„Velmi dobrá a rychlá spolupráce. Doporučuji!“

Leoš Kaucký
Google
★ ★ ★ ★ ★

„Přesně takto si představujeme profesionální práci. Dekujeme“

STAVILLI
Google
★ ★ ★ ★ ★

„Ať už se jedná o optimalizaci webu, nebo tvorbu na míru oceňuji kromě profesionální práce a znalostí problematiky také férový přístup a komunikaci.“

Aleš Illický
Google
★ ★ ★ ★ ★

„Děkuji za profesionální spolupráci, vše dle domluvy, naprostá spokojenost a mohu jen vřele doporučit.... Při dalších projektech určitě opět využiji Vašich služeb“

Peter Spilak
Google
★ ★ ★ ★ ★

„Profesionalita a velká ochota, nemohu jinak než doporučit“

Magdalena Vašková
Google
★ ★ ★ ★ ★

„Skvělá zkušenost při tvorbě webu, profesionální přístup, rychlost, ochota pomoci“

Jana Kono
Google
★ ★ ★ ★ ★

„Rychlá spolupráce a komunikace – mohu jen doporučit.“

Gawix
Google
★ ★ ★ ★ ★

„Moc mi pomohl, když jsem potřebovala pomoc s webem. A bylo to gratis :)). Jsem mu neskonale vděčná.“

Radka Arbesová
Google
★ ★ ★ ★ ★

„Děkuji Jiřímu za rychlou a kvalitní spolupráci na tvorbě webu. Srozumitelná a ochotná komunikace mě vždycky potěší a přináší důvěru.“

Jiří Mařík
Google
★ ★ ★ ★ ★

„Jsem maximálně spokojená. Rychlost, ochota a cenově dostupné. Děkuji“

Veronika Černá
Google
★ ★ ★ ★ ★

„Naprostá spokojenost. Rychlá komunikace, skvělá cena a odborná pomoc. Moc děkuji :)“

Patricie Kučerová
Google
★ ★ ★ ★ ★

„Velká spokojenost, rychlost a p. Vančura moc dobře ví co dělá. :)“

Ondřej Daniško
Google
★ ★ ★ ★ ★

„dobrá práce, rychlá odezva“

Zuzana Jírová
Google
★ ★ ★ ★ ★

„S programátory mám zkušeností hodně, ale tady musím opravdu pochválit. Pro mě a mé přátele vytvořil skvělý nástroj na evidenci sbírek a opravdu se to povedlo. Bylo to hotové rychle, kvalitně a za skvělou cenu. Komunikace funguje velmi rychle, což je super a ne úplně standard. Díky za super práci, za mě 100% spokojenost!“

Zdeněk
Google
★ ★ ★ ★ ★

„Vše bylo rychlé a hlavně to funguje. Dobrá práce.“

Lukáš Bartášek
Google
★ ★ ★ ★ ★

„Normálně recenze nepíši, ale zde rád doporučím kvalitní práci. Jiří pro mě vytvořil web pro dětské tábory. Kvalitní práce, rychlá komunikace a vlastní nápady, které Jiří sám přidá, jsou na velice vysoké úrovni. Nemohu hodnotit jinak než 5/5.“

Tomáš Loněk
Google
★ ★ ★ ★ ★

„Pan Jiri nam delal jiz 3 webove stranky a vzdy velka spokojenost, je mega rychly a vse hned kladne vyridi, mohu pouze doporucit. Poradi si bez problemu i s rezervacnimi kalendaremi, udrzbou socialnich siti, atd.“

Barbara Mašková
Google