RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 635377
Accepted
Sergei R
Sergei R
Asked:2020-03-04 21:21:38 +0000 UTC2020-03-04 21:21:38 +0000 UTC 2020-03-04 21:21:38 +0000 UTC

基础迁移到 Heroku

  • 772

ruby on rails中有一个应用

模式.rb

ActiveRecord::Schema.define(version: 20170302072830) do

create_table "stocks", force: :cascade do |t|
  t.string   "name",       null: false
  t.integer  "unit_price", null: false
  t.integer  "interest",   null: false
  t.integer  "duration",   null: false
  t.datetime "created_at", null: false
  t.datetime "updated_at", null: false
  t.integer  "user_id"
  t.index ["user_id"], name: "index_stocks_on_user_id", using: :btree
end

create_table "users", force: :cascade do |t|
  t.string   "email",               default: "", null: false
  t.string   "encrypted_password",  default: "", null: false
  t.string   "username",            default: "", null: false
  t.datetime "remember_created_at"
  t.integer  "sign_in_count",       default: 0,  null: false
  t.datetime "current_sign_in_at"
  t.datetime "last_sign_in_at"
  t.string   "current_sign_in_ip"
  t.string   "last_sign_in_ip"
  t.datetime "created_at",                       null: false
  t.datetime "updated_at",                       null: false
  t.index ["email"], name: "index_users_on_email", unique: true, using: :btree
end
end

开发过程中有几次迁移

在此处输入图像描述

迁移到 Heroku heroku rake db:migrate

我得到一个日志

在此处输入图像描述

持续时间字段及其整数类型如何?类型从日期更改为整数。

ALTER TABLE "stocks" ALTER COLUMN "duration" TYPE integer PG::DatatypeMismatch: ERROR: column "duration" cannot be cast automatically to type integer

好吧,他的暗示并没有告诉我任何事情。

提示:您可能需要指定“USING duration::integer”。

ruby-on-rails
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    user181100
    2020-03-05T22:55:54Z2020-03-05T22:55:54Z

    您的类型更改可能会导致数据丢失。PostgreSQL只隐式地做那些不会导致损失的转换,但是你传递给一个更“窄”的类型,所以你必须明确指定如何转换现有的值。这是一种预防措施,因此您不会轻弹一下手腕就毁掉自己的数据。

    Postgres 甚至向您建议如何在 postgres 语言级别修复列更改命令,您只需将此建议翻译成 railmigration 语法:

    change_column :stocks, :duration, "integer USING duration::integer"
    #                    явное преобразование  ^^^^^^^^^^^^^^^^^^^^^^^
    
    • 1
  2. Sergei R
    2020-03-05T17:13:45Z2020-03-05T17:13:45Z

    可能是由于在不同的迁移中相同的字段我有不同的数据类型,所以发生了这个错误。

    新的迁移不改变字段类型,而是删除它并创建一个新的是正确的。

    在我的例子中,我完全删除了旧的迁移,创建了一个新的迁移,我在其中指出所有表都已经正确的数据,这解决了问题。

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5