gpt4 book ai didi

sql - 无法分配 id, "Column ' id'不能为空"

转载 作者:太空宇宙 更新时间:2023-11-03 16:55:07 25 4
gpt4 key购买 nike

我继承了一个使用 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

最佳答案

终于开始做这件事了,只需要做一条 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 选择调用, 然后可以修改。

关于sql - 无法分配 id, "Column ' id'不能为空",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12194372/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com