Rails3 ActiveRecords отображает столбец с неправильным типом данных? - PullRequest
1 голос
/ 30 октября 2010

Я не уверен, как озаглавить этот вопрос, он довольно странный. Ну, вот в чем дело, я создал модель под названием UserProfiles, для которой файл миграции выглядит следующим образом:

  class CreateUserProfiles < ActiveRecord::Migration
  def self.up
    create_table :user_profiles, :primary_key => :id, :options => "auto_increment = 1"  do |t|
      t.integer :id
      t.references :user
      t.string  :first_name, :limit   => 20
      t.string  :middle_name, :limit   => 20
      t.string  :last_name, :limit   => 20

      t.string  :address_line_1, :limit   => 50
      t.string  :address_line_2, :limit   => 50
      t.string  :address_line_3, :limit   => 50
      t.string  :city, :limit   => 20
      t.string  :state, :limit   => 20
      t.string  :country, :limit   => 2
      t.string  :zipcode, :limit  => 10

      t.string  :phone, :limit   => 20
      t.string  :mobile, :limit   => 20
      t.string  :email,  :limit   => 100


      t.string  :photo_url, :limit  => 256
      t.integer :photo_id

      t.date    :dob
      t.string  :passport_no, :limit => 20
      t.string  :nationality, :limit => 2


      #t.string  :ssr_meal,   :limit => 20
     # t.string  :ssr_disability, :limit  => 20
     # t.string  :ssr_seating, :limit  => 20
     # t.string  :ssr_other, :limit  => 20


      t.timestamps
    end
  end

  def self.down
    drop_table :user_profiles
  end
end

в командной строке rails [rails c], когда я набираю: "UserProfiles", я получаю следующее:

irb(main):009:0> UserProfile
=> UserProfile(id: integer, user_id: integer, first_name: string, middle_name: string, las
t_name: string, address_line_1: string, address_line_2: string, address_line_3: string, ci
ty: string, state: string, country: string, zipcode: string, phone: string, mobile: string
, email: string, photo_url: string, photo_id: integer, dob: date, passport_no: string, nat
ionality: string, created_at: datetime, updated_at: datetime)

Проблема в том, что, когда я выводю / получаю определенную запись через UserProfiles.all или UserProfiles.find, кажется, что ActiveRecords смешивает типы данных и показывает мне недопустимые данные, как в случае ниже:

irb(main):010:0> UserProfile.all
=> [#<UserProfile id: 19, user_id: 1, first_name: "Sriram", middle_name: "", last_name: "C
handrasekaran", address_line_1: "", address_line_2: "", address_line_3: #<BigDecimal:4f4f3
28,'0.0',4(8)>, city: "", state: #<BigDecimal:4f4f280,'0.0',4(8)>, country: nil, zipcode:
0.0, phone: 0, mobile: 0, email: nil, photo_url: nil, photo_id: nil, dob: #<BigDecimal:4f4
f0b8,'0.1993E4',4(8)>, passport_no: #<BigDecimal:4f4f058,'0.0',4(8)>, nationality: "IN", c
reated_at: "2010-10-30 17:32:11", updated_at: "2010-10-30 18:35:36">]
irb(main):011:0>

Таким образом, хотя DOB (Дата рождения) хранится в MySQL как 1993-07-01, она отображает его как 1993.0. Я проверил данные, хранящиеся на MySQL, с помощью Navicat. Так что может показаться, что проблема в какой-то вещи для декодирования, которую я не могу определить [будучи новичком в ruby ​​и rails]. alt text

Моя модель UserProfile выглядит следующим образом:

class UserProfile < ActiveRecord::Base
  belongs_to  :user
  has_one :primary_user_profile
end

Любая помощь или понимание этой проблемы очень ценится. Спасибо!

Edit:

@ Time Machine: я пытался использовать помощник по форме date_select, но он заполнял бы только год. Как и в. Я мог бы использовать его, чтобы отправить данные в базу данных ... но когда дело дошло до отображения, показывал только год. Так же, как текстовое поле.

@ Zetac: В моем файле schema.rb много комментированных ошибок ... не знаю, что с этим делать. Все таблицы были разработаны только для миграции. Schema.rb

ActiveRecord::Schema.define(:version => 20101026142802) do
# Could not dump table "user_profiles" because of following ArgumentError
#   invalid date
end

Кажется, что две прокомментированные строки повторяются для каждой таблицы в базе данных / каждая модель мигрировала через ruby.

Из моей консоли базы данных:

mysql> desc travel.user_profiles;
+----------------+--------------+------+-----+---------+----------------+
| Field          | Type         | Null | Key | Default | Extra          |
+----------------+--------------+------+-----+---------+----------------+
| id             | int(11)      | NO   | PRI | NULL    | auto_increment |
| user_id        | int(11)      | YES  |     | NULL    |                |
| first_name     | varchar(20)  | YES  |     | NULL    |                |
| middle_name    | varchar(20)  | YES  |     | NULL    |                |
| last_name      | varchar(20)  | YES  |     | NULL    |                |
| address_line_1 | varchar(50)  | YES  |     | NULL    |                |
| address_line_2 | varchar(50)  | YES  |     | NULL    |                |
| address_line_3 | varchar(50)  | YES  |     | NULL    |                |
| city           | varchar(20)  | YES  |     | NULL    |                |
| state          | varchar(20)  | YES  |     | NULL    |                |
| country        | varchar(3)   | YES  |     | NULL    |                |
| zipcode        | varchar(10)  | YES  |     | NULL    |                |
| phone          | varchar(20)  | YES  |     | NULL    |                |
| mobile         | varchar(20)  | YES  |     | NULL    |                |
| email          | varchar(100) | YES  |     | NULL    |                |
| photo_url      | varchar(256) | YES  |     | NULL    |                |
| photo_id       | int(11)      | YES  |     | NULL    |                |
| dob            | date         | YES  |     | NULL    |                |
| passport_no    | varchar(20)  | YES  |     | NULL    |                |
| nationality    | varchar(3)   | YES  |     | NULL    |                |
| created_at     | datetime     | YES  |     | NULL    |                |
| updated_at     | datetime     | YES  |     | NULL    |                |
+----------------+--------------+------+-----+---------+----------------+
22 rows in set (0.01 sec)

Когда я просматриваю navicat, данные из формы успешно сохраняются в базе данных, но при их отображении возникает проблема.

РЕДАКТИРОВАТЬ 2:

Проблема, похоже, заключается в том, как гем mysql2 взаимодействует с MySQL. Я переключился на PostgreSQL, и проблема исчезла.

Schema.rb теперь читает:

ActiveRecord::Schema.define(:version => 20101026142802) do

  create_table "flight_prices", :force => true do |t|
    t.integer  "flight_schedule_id"
    t.decimal  "price_usd",                         :precision => 8,  :scale => 2
    t.decimal  "price_other",                       :precision => 10, :scale => 2
    t.string   "price_other_country", :limit => 2
    t.datetime "created_at"
    t.datetime "updated_at"
    t.string   "booking_code",        :limit => 2
    t.string   "booking_class",       :limit => 20
    t.string   "fare_code",           :limit => 10
    t.text     "fare_rules"
  end

  create_table "flight_schedules", :force => true do |t|
    t.string   "id_iata",           :limit => 3
    t.string   "id_icao",           :limit => 3
    t.string   "flight_number",     :limit => 7
    t.string   "departure_airport", :limit => 3
    t.string   "arrival_airport",   :limit => 3
    t.datetime "departure"
    t.datetime "departure_utc"
    t.datetime "arrival"
    t.datetime "arrival_utc"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "primary_user_profiles", :force => true do |t|
    t.integer  "user_id"
    t.integer  "user_profile_id"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "static_airlines", :force => true do |t|
    t.string "iata",        :limit => 3
    t.string "icao",        :limit => 3
    t.string "name",        :limit => 64
    t.string "country_iso", :limit => 2
  end

  create_table "static_airports", :force => true do |t|
    t.string   "iata",               :limit => 3
    t.string   "label",              :limit => 128
    t.string   "name",               :limit => 128
    t.string   "locale",             :limit => 128
    t.string   "static_country_iso", :limit => 2
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "static_countries", :force => true do |t|
    t.string "iso",           :limit => 2
    t.string "label_english", :limit => 64
    t.string "label_local",   :limit => 64
  end

  create_table "user_profiles", :force => true do |t|
    t.integer  "user_id"
    t.string   "first_name",     :limit => 20
    t.string   "middle_name",    :limit => 20
    t.string   "last_name",      :limit => 20
    t.string   "address_line_1", :limit => 50
    t.string   "address_line_2", :limit => 50
    t.string   "address_line_3", :limit => 50
    t.string   "city",           :limit => 20
    t.string   "state",          :limit => 20
    t.string   "country",        :limit => 2
    t.string   "zipcode",        :limit => 10
    t.string   "phone",          :limit => 20
    t.string   "mobile",         :limit => 20
    t.string   "email",          :limit => 100
    t.string   "photo_url",      :limit => 256
    t.integer  "photo_id"
    t.date     "dob"
    t.string   "passport_no",    :limit => 20
    t.string   "nationality",    :limit => 2
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "users", :force => true do |t|
    t.string   "email",                               :default => "", :null => false
    t.string   "encrypted_password",   :limit => 128, :default => "", :null => false
    t.string   "password_salt",                       :default => "", :null => false
    t.string   "reset_password_token"
    t.string   "remember_token"
    t.datetime "remember_created_at"
    t.integer  "sign_in_count",                       :default => 0
    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.string   "confirmation_token"
    t.datetime "confirmed_at"
    t.datetime "confirmation_sent_at"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  add_index "users", ["email"], :name => "index_users_on_email", :unique => true
  add_index "users", ["reset_password_token"], :name => "index_users_on_reset_password_token", :unique => true

end

Будучи простым смертным в области Ruby & Rails, я не могу исправить ошибку mysql2. он указан здесь GitHub кем-то еще.

Также для справочной информации, если кто-то еще может решить проблему. Я использую Rails 3.0.1, MySQL 5.1 32bit на Windows Server 2008R2 (64bit), Ruby версии 1.9.2 и последнюю версию mysql2 gem.

1 Ответ

0 голосов
/ 22 февраля 2011

Измените тип данных dob на datetime вместо date.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...