-
Notifications
You must be signed in to change notification settings - Fork 11.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Problem modifying column type from text to mediumText or longText #21847
Comments
Creating it as mediumText: Works fine. So this is how I'm doing it: public function migrateUp()
{
Schema::table('ci_runs', function (Blueprint $table) {
$table->mediumText('log_new')->nullable();
});
Database::statement('update ci_runs set log_new = log;');
Schema::table('ci_runs', function (Blueprint $table) {
$table->dropColumn('log');
$table->renameColumn('log_new', 'log');
});
} To get To have that column in the correct order, I changed it to
|
Very good point. That explains why Your solution only works on a test server as |
@Dimimo It will loose nothing, it creates the new column, copies old logs to it, then drops the old one and renames it back to log |
First off, it isn't Doctrine that is adding the +1 values, that's still in Laravel's code base. The calculations have been done this way for over three years, since at least Laravel 5.0 / 2014. I tracked it back to 24828f0 but that may not be the first occurrence. Changing these now will introduce breaking changes to migrations that has worked for a very long time. Every column someone has changed to these types in the last three years will suddenly be changed differently when the migrations are reran in development environments, putting the local environment out-of-sync with production. My views on any changes to the migration system is as my views to any changes to migrations that have been pushed from the local machine; it should never happen. Migrations need to be stable. Being stable over time and releases is more important, according to me, than being correct. There are already a lot of red boxes in the migration documentation about weird cases and unsupported things. We could document this behavior in another red box. |
I've found that changing any text column type to another text column type does not work at all, even changing Unfortunately a proper fix to this would require mapping every type not supported by Doctrine. This seems to be the same issue from #8840. I haven't found yet, but maybe there's an easier way to fake those types to force Doctrine to change the columns correctly. 🤔 |
This is not an issue of Laravel. dbal has the issue. It ignores the TextType length property when comparing the columns so it doesn't know it actually changed in order to generate the appropriate DDL. You can find more info at doctrine/dbal#2566 (comment). Hopefully it will be sorted out soon, you are more than welcome to jump in the discussion. @antonioribeiro, i like your workaround (#21847 (comment)), looks cleaner that using Alter db statements. |
Since this seems to be an issue with dbal I'm going to close this here. |
Another workaround that I`ve found. I know it is not elegant or pretty, but it is a working workaround.. |
@88chico You're my hero |
@88chico Thank you! I wish "doctrine/dbal" would fix this bug reported >2 years ago, but until they do, your hack seemed to work for my purposes. |
Check solution proposed here: doctrine/dbal#2566 (comment), very nice one! |
The solution mentioned above by @bhulsman is the easiest workaround: making a change to the column's comment triggers the type change:
|
Description:
Changing columns from
text
tomediumText
orlongText
changes to the wrong size.Text
is supposed to be 65536 chars long, but the sources are getting information fromstatic::calculateDoctrineTextLength($fluent['type']);
:Which sets text (default) as 255, which is the
string
length in Laravel:Then for doctrine, mediumText is 65536 bytes, which is
Text
and so on.So this migration:
Changes a
text
column to the very sametext
length.Dumping the results from
I get
Which is also odd, since Doctrine is basically adding one byte to the columns length.
And looking at the table structure in SequelPro, this is before:
This is after a migration to
longText
(went to the biggest to test it):And this is what happens if I manually modify the column:
The text was updated successfully, but these errors were encountered: