当前位置: 首页 > 知识库问答 >
问题:

时间戳更改字段上的迁移错误

壤驷高洁
2023-03-14

在laravel 5.7/mysql 5应用程序中,我想将默认值设置为timestamp字段(创建时未设置):

   $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"
        ]
    }
}

通过谷歌搜索,我发现我还需要安装marktopper/dbal时间戳类型https://github.com/art-institute-of-chicago/data-aggregator/commit/581f4f318468681c71c62103280daedc67bbe118我安装了它,运行迁移时并没有错误,但并没有定义默认时间戳处的created_,所以添加的新行在created_中为null。

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

谢谢

共有1个答案

叶晋
2023-03-14

文档说明您不能更改/修改时区列类型。

只能“更改”以下列类型:bigInteger、binary、boolean、date、dateTime、dateTimeTz、decimal、integer、json、longText、mediumText、smallInteger、string、text、time、unsignedBigInteger、unsignedInteger和unsignedSmallInteger。

最好的办法是使用一个原始的sql查询来更新列,比如:

DB::statement('ALTER TABLE `table_name` CHANGE `column_name` `column_name` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP;');
 类似资料:
  • 问题内容: 假设我最初创建了一个ndb.Model,并且想要更改字段的ndb属性类型(例如,将IntegerProperty更改为StringProperty),但是想要转换存储在该字段中的当前数据,以免丢失该数据。一种方法是简单地创建一个新的字段名,然后使用脚本迁移数据,但是还有其他更方便的方法来完成此操作吗? 例如,假设我有以下模型: 我存储了一个实体实例: 并希望将production_ye

  • SQLAlchemy变更日志和迁移指南现在集成在主文档中。 当前迁移指南 SQLAlchemy 1.4有什么新功能? SQLAlchemy 2.0概述和状态 迁移到Alchemy 更改日志 1.4变更日志 1.3换热器 1.2换热器 1.1换热器 1换热器 0.9换热器 0.8换热器 0.7换热器 0.6换热器 0.5换热器 0.4换热器 0.3换热器 0.2换热器 0.1换热器 旧的迁移指南 S

  • 我更改了一个错误的flyway脚本,这使我的迁移处于错误状态(我有5个脚本版本,但当我运行我的应用程序时,它从第4个开始,并得到一个错误“反应已经存在”)。我尝试从flyway cli使用clean,但它没有完全解决问题...此外,当我尝试将我的分支推送到git时,CI/CD管道将无法进行迁移。既然我在开发环境中,全部删除迁移脚本会是一个可怕的想法吗?删除所有脚本是否允许我在开发环境中“从头开始”

  • 我们使用核心JMS客户机库,通过Boomi中的JMS连接器向ActiveMQ Artemis 2.11.0发送消息。但是,当通过ActiveMQ管理控制台查看队列中的消息时,队列中消息的时间戳与当前时间和日期不同。队列中的消息是从今天开始的,但您可以看到它的日期是去年9月: 你知道如何修复这个配置吗?

  • 我正在使用FluentD(v.12最后一个稳定版本)向Kafka发送消息。但是FluentD正在使用一个旧的KafkaProducer,所以记录时间戳总是设置为-1。因此,我必须使用WallclockTimestampExtrator将记录的时间戳设置为消息到达kafka时的时间点。 是否有特定于Kafka Streams的解决方案? 我真的感兴趣的时间戳,是由Fluentd在消息中发送的: “时

  • 问题内容: 我正在使用Eloquent进行数据库处理,当我使用更新方法更新记录时,时间戳被更改了,如何防止这种情况发生? 时间戳工作正常 问题答案: 如果您的模型中没有任何自定义设置。您可以像这样更新记录: 仅应使用此代码更新时间戳(而不是)。如果还进行了更新,则意味着您可能具有一些自定义模型设置,或者: 您可能具有数据库触发器,这些触发器在记录更新时会发生变化 您可能已经注册了一些事件,这些事件