Ошибка миграции в поле изменения метки времени - PullRequest
0 голосов
/ 18 января 2019

В приложении laravel 5.7 / mysql 5 я хочу установить значение по умолчанию в поле отметки времени (оно не было задано при создании):

   $table->timestamp('created_at')->useCurrent()->change();

Но я получил ошибку:

 Unknown column type "timestamp" requested. Any Doctrine type that you use has to be registered with \Doctrine\DBAL\Types\Type::addType(). You can get a list of all the known types with \Doctrine\DBAL\Types\Type::getTypesMap(). If this error occurs during database introspection then you might have forgotten to register all database types for a Doctrine Type. Use AbstractPlatform#registerDoctrineTypeMapping() or have your custom types implement Type#getMappedDatabaseTypes(). If the type name is empty you might have a problem with the cache or forgot some mapping information.

  at /mnt/_work_sdb8/wwwroot/lar/BoxBooking2/vendor/doctrine/dbal/lib/Doctrine/DBAL/DBALException.php:267
    263|      * @return \Doctrine\DBAL\DBALException
    264|      */
    265|     public static function unknownColumnType($name)
    266|     {                                                                                                                                                                                                         
  > 267|         return new self('Unknown column type "' . $name . '" requested. Any Doctrine type that you use has ' .                                                                                                
    268|             'to be registered with \Doctrine\DBAL\Types\Type::addType(). You can get a list of all the ' .                                                                                                    
    269|             'known types with \Doctrine\DBAL\Types\Type::getTypesMap(). If this error occurs during database ' .                                                                                              
    270|             'introspection then you might have forgotten to register all database types for a Doctrine Type. Use ' .                                                                                          
    271|             'AbstractPlatform#registerDoctrineTypeMapping() or have your custom types implement ' .                                                                                                           

Обычно у меня нет проблем с полями меток времени, и я полагаю, что метод -> изменение поднял эту проблему. Как это исправить?

МОДИФИЦИРОВАННЫЙ БЛОК № 1: У меня это установлено мой композитор.json:

{
    "name": "laravel/laravel",
    "type": "project",
    "description": "The Laravel Framework.",
    "keywords": [
        "framework",
        "laravel"
    ],
    "license": "MIT",
    "require": {
        "php": "^7.1.3",
        "doctrine/dbal": "^2.9",
        "fideloper/proxy": "^4.0",
        "laravel/framework": "5.7.*",
        "laravel/tinker": "^1.0",
        "marktopper/doctrine-dbal-timestamp-type": "^1.0",
        "mews/purifier": "^2.1",
        "proengsoft/laravel-jsvalidation": ">2.2.0",
        "yajra/laravel-datatables-oracle": "~8.0"
    },
    "require-dev": {
        "beyondcode/laravel-dump-server": "^1.0",
        "filp/whoops": "^2.0",
        "fzaninotto/faker": "^1.4",
        "mockery/mockery": "^1.0",
        "nunomaduro/collision": "^2.0",
        "phpunit/phpunit": "^7.0"
    },
    "config": {
        "optimize-autoloader": true,
        "preferred-install": "dist",
        "sort-packages": true
    },
    "extra": {
        "laravel": {
            "dont-discover": []
        }
    },
    "autoload": {
        "psr-4": {
            "App\\": "app/"
        },
        "classmap": [
            "database/seeds",
            "database/factories"
        ]
    },
    "autoload-dev": {
        "psr-4": {
            "Tests\\": "tests/"
        }
    },
    "minimum-stability": "dev",
    "prefer-stable": true,
    "scripts": {
        "post-autoload-dump": [
            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
            "@php artisan package:discover --ansi"
        ],
        "post-root-package-install": [
            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
        ],
        "post-create-project-cmd": [
            "@php artisan key:generate --ansi"
        ]
    }
}

Поиск в Google Я обнаружил, что мне нужно также установить marktopper / doctrine-dbal-timestamp-type https://github.com/art-institute-of-chicago/data-aggregator/commit/581f4f318468681c71c62103280daedc67bbe118 Я установил его, и у меня нет ошибки при выполнении миграции, но временная метка по умолчанию, созданная по умолчанию для create_at, НЕ определена, поэтому добавленная новая строка имеет значение null в созданной_каталоге.

$ php artisan --version
Laravel Framework 5.7.21
$ node -v 
v10.15.0
$ npm -v 
6.5.0

Спасибо!

1 Ответ

0 голосов
/ 30 января 2019

В документации указано, что вы не можете изменять / изменять типы столбцов часовых поясов.

Только следующие типы столбцов могут быть изменены: bigInteger, двоичный, логический, дата, dateTime, dateTimeTz, десятичное, целое, json, longText, mediumText, smallInteger, строка, текст, время, unsignedBigInteger, unsignedInteger и unsignedSmallInteger.

Лучше всего использовать необработанный SQL-запрос, чтобы обновить столбец примерно так:

DB::statement('ALTER TABLE `table_name` CHANGE `column_name` `column_name` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP;');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...