2

Rails を使用して段階的に設定されずid、2 つの主キーを持つデータベースを継承しました。

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`)) 

ただし、ルビーを使用してこのテーブルに挿入しようとすると、次のようになります。

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
4

1 に答える 1

0

SQLステートメントを実行するだけで、ついにそれを実行するようになりました。Rails/Ruby に SQL コードのラッパーがあることを見て、Rails を使用したかったのですが、うまくいきませんでした。最終的には、次のようになります。

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)

他に変更された唯一の点は、select 呼び出しで返されるようにクラスの説明TUserHistoryが追加され、その後変更できるようになったことです。history_notuser

于 2012-09-03T05:19:02.237 に答える