friendly_id(4.0.0.beta12)の宝石をSTIモデルで正しく動作させるための設定方法については、かなり不便です。Friendly_Id w/STIの使い方は?
Toyota.create!(name: "test")
Ford.create!(name: "test")
生じる誤差がある:問題はそのfriendly_idの選択ルックスです
(0.1ms) BEGIN
Ford Load (0.2ms) SELECT `cars`.* FROM `cars` WHERE `cars`.`type` IN ('Ford') AND (`slug` = 'test' OR `slug` LIKE 'test--%') AND (id <> 7606) ORDER BY LENGTH(`slug`) DESC, `slug` DESC LIMIT 1
(0.5ms) UPDATE `cars` SET `slug` = 'test', `updated_at` = '2011-09-30 15:06:08' WHERE `cars`.`type` IN ('Ford') AND `cars`.`id` = 7606
(0.1ms) ROLLBACK
ActiveRecord::RecordNotUnique: Mysql2::Error: Duplicate entry 'test' for key 2: UPDATE `cars` SET `slug` = 'test', `updated_at` = '2011-09-30 15:06:08' WHERE `cars`.`type` IN ('Ford') AND `cars`.`id` = 7606
私はこのような何かをしようとした場合
class Car < ActiveRecord::Base
extend FriendlyId
friendly_id :name, :use => :slugged
end
class Ford < Car
end
class Toyota < Car
end
:ここ
は、モデルのセットアップですslug w/typeが 'Ford'に設定され、きれいになる(スラッグ 'test'はすでにタイプ 'トヨタ')。 「テスト」という名前のスラッグがないと仮定すると、スラッグ「テスト」でレコードを保存しようとすると、すべてが地獄になります。アイデア?
ありがとうございました!
? –
こんにちはナッシュ、私はfriendly_id(4.0.0.beta12)を使用しています(質問も更新)ありがとう。 –
おそらく私のgemファイルに 'gem 'friendly_id'、 '〜> 4.0.0.beta8''が追加されるはずですが、4.0.0.beta12は' bundle install'を実行するときにインストールされるものです –