我使用 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