質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

Q&A

解決済

1回答

1099閲覧

主キーを任意のカラムに設定したい。 ruby マイグレーションファイル

masaosan18

総合スコア65

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

0グッド

0クリップ

投稿2020/10/16 03:22

編集2020/10/16 03:46

テーブル作成方法に関して質問です。
主キーをデフォルトのIDではなく、指定のカラムに設定したいのですがうまくいきません。
詳しい方、教えていただきたいです:おじぎ_男性:
Cityテーブルを作成しています。

参考にした記事
Rails で id 以外を主キー(primary_key)に設定する

イメージとしては、
city_number | name | 作成日 | 更新日
のような設計にしたく、主キーをcity_numberにしたいです。
これが現在の記述ではうまく行きません。

Key column 'city_number' doesn't exist in table
上記のようなエラーがでてしまい、db:migrateすることができずにいます。

コード

ruby

1class CreateCities < ActiveRecord::Migration[6.0] 2 def change 3 create_table :cities, primary_key: :city_number do |t| 4 t.string :name 5 t.references :prefecture, foreign_key: true 6 t.timestamps 7 end 8 end 9end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

_dana

2020/10/16 03:28

citiesテーブルは未作成の状態ですか?
masaosan18

2020/10/16 03:47

db:migrate:resetしています
_dana

2020/10/16 04:08

schema.rbというファイルでCityテーブルを作成する旨の記述があった場合リセット後に再作成されると思うのですが確認できますでしょうか phpmyadminやsequel pro等でDBの中身がわかればいいのですが
no1knows

2020/10/16 04:29

「:おじぎ_男性:」が気になりますね。
masaosan18

2020/10/16 05:00

schemaに反映されるまえの段階です。
masaosan18

2020/10/16 05:00

「:おじぎ_男性:」とは?
_dana

2020/10/16 05:30

dbに何もない状態でresetしたということですか? :おじぎ_男性:というワードが質問文にあるのですがおそらく絵文字か何かがteratail側で表示できずalt表示みたいになってしまったのではないかと思われます
guest

回答1

0

ベストアンサー

primary_key を id にしたままでも、city_code で関連つけることは可能ですがそうはしたくない、ということでしょうか。
primaryをid以外にすると思わぬトラブルに遭遇することがあるのでやるのでしたらその覚悟で。(他人作成のprojectのメンテで経験あり、なんだったか詳しくは忘れました。joinsをつかってゴチョゴチョやるときだったかな)

参照の方法を使ったことはないのですが双方の記述をみると可能性は Railsのversion違いが有るのかもしれません。
「Key column 'city_number' doesn't exist in table」
というエラーメッセージなのですから作ってみたらどうでしょう
t.bignum :city_code (string かな?)
を追加してみてください。
うまく行ったら、indexを作っておくことをお忘れなく。

投稿2020/10/18 00:22

winterboum

総合スコア23567

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問