ActiveRecordに以下を使用してコンソールのテーブルを一覧表示するように依頼できることを知っています。
ActiveRecord::Base.connection.tables
特定のテーブルの列をリストするコマンドはありますか?
これにより、テーブルのcolumn_namesがリストされます。
Model.column_names
e.g. User.column_names
これは列名だけでなく列を取得し、ActiveRecord :: Base :: Connectionを使用するため、モデルは不要です。データベースの構造をすばやく出力するのに便利です。
ActiveRecord::Base.connection.tables.each do |table_name|
puts table_name
ActiveRecord::Base.connection.columns(table_name).each do |c|
puts "- #{c.name}: #{c.type} #{c.limit}"
end
end
Rails threeを使用すると、モデル名を入力できます。
> User
gives:
User(id: integer, name: string, email: string, etc...)
Rails fourでは、最初に接続を確立する必要があります。
irb(main):001:0> User
=> User (call 'User.connection' to establish a connection)
irb(main):002:0> User.connection; nil #call nil to stop repl spitting out the connection object (long)
=> nil
irb(main):003:0> User
User(id: integer, name: string, email: string, etc...)
SQLコマンドに慣れている場合は、アプリのフォルダーに入り、Rails db
の簡単な形式であるRails dbconsole
を実行できます。 sqliteであろうとmysqlであろうと、データベースのシェルに入ります。
次に、次のようなsqlコマンドを使用してテーブル列を照会できます。
pragma table_info(your_table);
コマンドラインツールでRails dbconsole
を実行して、sqliteコンソールを開くことができます。次に、.tables
と入力してすべてのテーブルをリストし、.fullschema
と入力して、列の名前とタイプを含むすべてのテーブルのリストを取得します。
たとえば、Rails console o Rails dbconsole:
学生はRailsコンソールを使用して私のモデルです:
$ Rails console
> Student.column_names
=> ["id", "name", "surname", "created_at", "updated_at"]
> Student
=> Student(id: integer, name: string, surname: string, created_at: datetime, updated_at: datetime)
Rails経由でSQLiteを使用するその他のオプション:
$ Rails dbconsole
sqlite> .help
sqlite> .table
ar_internal_metadata relatives schools
relationships schema_migrations students
sqlite> .schema students
CREATE TABLE "students" ("id" integer PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "surname" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL);
最後に詳細をご覧ください。
sqlite> .help
お役に立てれば!
テーブルの列をリストするには、通常これを使用します。Model.column_names.sort
。i.e. Orders.column_names.sort
列名をソートすると、探しているものを簡単に見つけることができます。
各列の詳細については、次を使用してください。Model.columns.map{|column| [column.name, column.sql_type]}.to_h
。
これにより、ニースハッシュが提供されます。例えば:
{
id => int(4),
created_at => datetime
}
よりコンパクトな形式で、入力を少なくする場合:
Portfolio.column_types