О записи базы данных обновления RoR

0

Я хотел бы использовать ruby ​​on rails и mysql для написания простой тестовой программы но в это время я не могу обновить запись базы данных. потому что я использую "середина" для замены столбца "id" в этом случае, что я могу сделать, чтобы обновить запись?

Проблема:

Mysql::Error: Unknown column 'id' in 'where clause': UPDATE `messages` SET `message` = 'ccc', `subject` = 'aaa', `author` = 'bbb' WHERE `id` = NULL

Мой код:

def update
    @message = Message.find(:first, :conditions => ["mid = ?", params[:id]])
    if @message.update_attributes(params[:message])
        flash[:notice] = 'Post was successfully updated.'
        redirect_to gbook_path(:id => @message.mid)
    else
        format.html { render :action => "edit" }
    end
end

База данных:

CREATE TABLE `demo_development`.`message` (
`mid` MEDIUMINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`subject` VARCHAR( 30 ) NOT NULL ,
`author` VARCHAR( 30 ) NOT NULL ,
`message` TEXT NOT NULL ,
`adddate` INT UNSIGNED NOT NULL
) ENGINE = MYISAM ;

1 ответ

5

Вам нужно указать ActiveRecord, что ваш первичный ключ не является условным обозначением 'id'.

Используйте метод set_primary_key.

class User < ActiveRecord::Base
  set_primary_key :mid
end

Документировано здесь: http://api.rubyonrails.org/classes/ActiveRecord/Base.html#M002290

Ещё вопросы

Сообщество Overcoder
Наверх
Меню