framework icon indicating copy to clipboard operation
framework copied to clipboard

->json() still creates nvarchar(max) columns on SQL Server 2025 despite native JSON datatype support

Open martijnvt1981 opened this issue 2 weeks ago • 4 comments

Laravel Version

12.40.2

PHP Version

8.3.25

Database Driver & Version

Microsoft SQL Server 2025 for MacOS Tahoe (26.1) (using Orbstack's Rosetta and Docker platform settings to emulate Intel)

Description

There is a problem with Laravel's Schema Builder when creating JSON columns on SQL Server 2025. Although SQL Server 2025 introduces native JSON datatype support, the ->json() method still creates nvarchar(max) columns instead of using the new native JSON datatype. This results in underutilization of important database features and may negatively impact performance and validation.

Moreover, there is no mechanism to detect the SQL Server version and conditionally use the native JSON datatype only when supported. For older SQL Server versions, the current fallback to nvarchar(max) should of course remain for backwards compatibility.

Steps To Reproduce

  1. Create a Laravel migration script defining a JSON column:

Schema::create('example_table', function (Blueprint $table) {
    $table->json('data');
});
  1. Run this migration on a SQL Server 2025 database.
  2. Check the datatype of the created column in the database.
  3. You'll see it's a nvarchar datatype instead of json

martijnvt1981 avatar Nov 28 '25 15:11 martijnvt1981