Как удалить объект ActiveRecord?
Я посмотрел на Active Record Querying, и у меня нет ничего при удалении, что я вижу.
Удалить
id,Удалить текущий объект как:
user.remove,Вы можете удалить, основываясь на
whereпредложении?
Как удалить объект ActiveRecord?
Я посмотрел на Active Record Querying, и у меня нет ничего при удалении, что я вижу.
Удалить id,
Удалить текущий объект как: user.remove,
Вы можете удалить, основываясь на whereпредложении?
Ответы:
Это destroyи destroy_allметоды, вроде
user.destroy
User.find(15).destroy
User.destroy(15)
User.where(age: 20).destroy_all
User.destroy_all(age: 20)
В качестве альтернативы вы можете использовать deleteи delete_allкоторые не будут принудительно применять :before_destroyи :after_destroyобратные вызовы или любые зависимые параметры связи.
User.delete_all(condition: 'value')позволит вам удалить записи без первичного ключа
Примечание : из комментария @ hammady не user.destroyбудет работать, если у модели User нет первичного ключа.
Примечание 2 : Из комментария @ pavel-chuchuva, destroy_allс условиями и delete_allс условиями устарела в Rails 5.1 - см. Guides.rubyonrails.org/5_1_release_notes.html
User.find_by(username:"bob") полезно для идентификации записи, которую нужно уничтожить или удалить.
Существует delete, delete_all, destroyи destroy_all.
Документы: старые документы и документы Rails 3.0.0
deleteне создает объекты, а destroyделает. В общем, deleteбыстрее чем destroy.
deleteбыстрее, но обходит обратные вызовы, которые вы могли определить на модели
User.destroyUser.destroy(1)удалит пользователя с помощью id == 1и :before_destroyи :after_destroyпроизойдет обратный вызов. Например, если у вас есть связанные записи
has_many :addresses, :dependent => :destroy
После уничтожения пользователя его адреса также будут уничтожены. Если вместо этого вы используете действие удаления, обратных вызовов не будет.
User.destroy, User.delete
User.destroy_all(<conditions>) или User.delete_all(<conditions>)
Примечание . Пользователь - это класс, а пользователь - объект экземпляра.
User.destroy_all()запускает обратные вызовы, поэтому, прежде чем что-либо удалить, загружает записи. Это два оператора SQL, а не один. Помимо влияния на производительность, это также влияет на параллелизм. Более безопасный вызов пропускает обратные вызовы; User.delete_all()выдаст только одну DELETE FROM...команду.