delete_all под областью поиска с соединениями в рельсах - PullRequest
0 голосов
/ 09 апреля 2011

У меня есть модель книги, модель тега и модель соединения, называемые bookstags, они выглядят следующим образом.

Когда я хочу прочитать все via_tags, Book.first.via_tags, с которыми он работает,
но когда я пытаюсь удалить все связанные via_tags, я попытался Book.first.via_tags.delete_all () и я получил исключение.

ActiveRecord::StatementInvalid: SQLite3::SQLException: near "INNER": syntax error: DELETE FROM "tags" INNER JOIN "books_tags" ON "tags".id = "books_tags".tag_id WHERE (("books_tags".book_id = 25)) AND ("tags"."kind" = 0)

Итак, я хочу спросить, возможно ли выполнить delete_all сприсоединяется?

class Book < ActiveRecord::Base
  has_many :tags, :through =>  :books_tags
end

class BooksTags < ActiveRecord::Base
  belongs_to :book
  belongs_to :tag
  def self.with_via_tag
    find(:all, :joins => :tag, :conditions => {:tags => {:kind => Tag.kind_index(:via)}})
  end
end

class Tags
  has_many :books_tags
  has_many :books, :through => :books_tags
  @kinds = [:via,:cate,:attr]
  def self.kind_index kind
    @kinds.index(kind)
  end
end

1 Ответ

0 голосов
/ 21 ноября 2013

Нет, потому что delete_all отбрасывает информацию о присоединении.Посмотрите этот ответ для альтернативного способа написания вашего запроса: https://stackoverflow.com/a/7639857/156109

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...