Active Record提供了兩種方式進行刪除操作。首先,有兩個類級別的方法,delete和delete_all,這兩個操作處在數據庫層面上,delete()方法接收一個或一組和數據庫對應的id,delete_all()方法刪除所有符合指定條件的記錄,如果沒有指定條件,就會刪除所有的記錄。方法的返回值和具體的數據庫適配器相關,例如oracle返回被影響的行數。如果沒有記錄被刪除,也不會拋出異常。
Order.delete(123) User.delete([2,3,4,5]) Product.delete_all(["price > ?", @expensive_price])
另外,destory方法刪除和數據庫中行相對應的Model對象,這樣會凍結這些對象,並且不能修改對象的值。
order = Order.find_by_name("Dave") order.destroy
有兩個類級別的destory方法,destory()方法接收一個或一組id,destory_all()方法接收刪除條件。這兩個方法都從數據庫中讀出對應的記錄到Model對象,並且對這個對象調用實例級別的destory()方法,而且不返回有意義的信息。
Order.destroy_all(["shipped_at < ?", 30.days.ago])
為什麼我們同時需要delete和destory方法呢?delete方法繞過了一些Active Record的回調(callback)和驗證函數,而使用destory則不會,通常我們使用destory方法來確保我們的數據庫是一致的,並且不會破壞Model中所包含的業務邏輯。