无法分配ID,"列' id'不能为空"

时间:2012-08-30 10:01:36

标签: sql ruby

我使用Rails继承了一个数据库,该数据库没有逐步设置id,并且还有两个主键:

CREATE TABLE `t_user_history` (
`id` int(11) NOT NULL,
`history_no` int(11) NOT NULL,
`user_login_id` varchar(10) COLLATE utf8_unicode_ci NOT NULL,
`user_name` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`user_pass` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`created_at` datetime DEFAULT NULL,
`updated_at` datetime DEFAULT NULL,
`deleted_at` datetime DEFAULT NULL,
`app_version` varchar(31) COLLATE utf8_unicode_ci DEFAULT NULL,
PRIMARY KEY (`history_no`,`id`)) 

但是,当我尝试使用ruby插入此表时:

tuser = TUserHistory.find_by_id(user.id)
TUserHistory.transaction do
ntuser = TUserHistory.new
ntuser.id = tuser.id
ntuser.history_no = 0
ntuser.user_login_id = tuser.user_login_id
ntuser.user_name = tuser.user_name
ntuser.user_pass = tuser.user_pass
ntuser.app_version = params[:app]
ntuser.save

我收到错误:

getName {"error_code":"Mysql2::Error: Column 'id' cannot be null: INSERT INTO `t_user_history` 
(`app_version`, `created_at`, `deleted_at`, `history_no`, `id`, `updated_at`, `user_login_id`, `user_name`, `user_pass`)
VALUES ('v1.2.9', '2012-08-30 09:26:57', NULL, 0, NULL, '2012-08-30 09:26:57', 'userlogin', 'username', 'userpass')"}

即使我设置了ntuser.id = 9127或其他值,它仍然会显示'id' cannot be null。 我查看了其他答案,表示确实可以修改此值,但似乎我尝试为ntuser.id设置的任何值都会被忽略。

不允许对表进行删除并以理智的方式重新开始,因为此表已被我们的服务使用。在我发现它没有自动递增之前,我想我会为user_id创建一个新列,但即使在进入该步骤之前也没有,甚至没有ntuser.id = 0或删除定义的行ntuser.id,有效。

这里发生了什么?为什么不识别数据已经通过?什么是最好的(没有,最快的)解决方法?

编辑:Rails版本3.1.0

TUserHistory类:

class TUserHistory < ActiveRecord::Base
set_table_name "t_user_history"
default_scope select("id, user_login_id,user_name,user_pass,app_version")
acts_as_paranoid
end

1 个答案:

答案 0 :(得分:0)

最后通过执行SQL语句来解决这个问题。我想使用rails,看看rails / ruby​​如何为SQL代码创建包装器,但它只是不起作用。最后,它看起来像:

tuser = TUserHistory.order("history_no DESC").find_by_id(user.id) #get last entry
    TUserHistory.transaction do
        id = tuser.id
        history_no = Integer(tuser.history_no)
        intHist_no = history_no + 1 #because this column doesn't auto-increment
        user_login_id = tuser.user_login_id
        user_name = tuser.user_name
        user_pass = tuser.user_pass
        app_version = params[:app]
        sql = "INSERT INTO t_user_history (id, history_no, user_login_id,user_name,user_pass,app_version) VALUES ('#{id}','#{intHist_no}','#{user_login_id}','#{user_name}','#{user_pass}','#{app_version}')"
         ActiveRecord::Base.connection.execute(sql)

唯一改变的是,TUserHistory的类描述添加了history_no,以便它会返回tuser选择调用,然后可以修改。