登录
首页 >  Golang >  Go问答

在 Golang 中如何进行 Gorm 的级联删除操作?

来源:stackoverflow

时间:2024-03-14 22:57:29 499浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《在 Golang 中如何进行 Gorm 的级联删除操作?》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题内容

我有一个表 customers with cars,cars 有 services。 当我删除汽车时,我还想从数据库中删除服务 当我删除客户时,我希望能够删除客户、其汽车、其服务。

我尝试了以下方法来删除汽车和与汽车相关的服务,但它只从数据库中删除汽车,如何删除汽车及其服务?

type Customer struct {
    gorm.Model

    FirstName string
    LastName  string
    Phone     string `gorm:"typevarchar(100);unique_index"`
    Cars      []Car  `gorm:"constraint:OnDelete:CASCADE;"`
}

type Car struct {
    gorm.Model

    Make       string
    Modelo     string
    Color      string
    VinNumber  string     `gorm:"typevarchar(100);unique_index"`
    Services   []*Service `gorm:"constraint:OnDelete:CASCADE;"`
    CustomerId int
}

type Service struct {
    gorm.Model

    Comment string
    Miles   string
    CarId   int
}

//endpoints
//delete customer
func deleteCustomer(w http.ResponseWriter, r *http.Request) {
    params := mux.Vars(r)

    setupResponse(&w, r)
    if (*r).Method == "OPTIONS" {
        return
    }

    var customer Customer
    db.First(&customer, params["id"])
    db.Unscoped().Delete(&customer)

    json.NewEncoder(w).Encode(&customer)
}

func deleteCar(w http.ResponseWriter, r *http.Request) {
    setupResponse(&w, r)
    if (*r).Method == "OPTIONS" {
        return
    }

    params := mux.Vars(r)

    var car Car
    db.First(&car, params["id"])
    db.Select("Services").Unscoped().Delete(&car)
    json.NewEncoder(w).Encode(&car)
}

我已经尝试了 stackoverflow 和文档中看到的大部分内容,但到目前为止似乎没有任何效果。


正确答案


在阅读了文档和一堆 stackoverflow 答案后,没有什么对我真正有用。文档和/或 stackoverflow 建议我在迁移模型时添加约束,或/并将约束添加到结构 gorm:"constraint:ondelete:cascade;" ,我也尝试了 db.select("cars").delete(&customers) 但没有成功。这就是我的做法,不确定这是否是最佳实践,但它会从数据库中删除其相关记录。 我更新了deletecustomer和deletecar端点,如下所示:

//delete customer
func deleteCustomer(w http.ResponseWriter, r *http.Request) {
    params := mux.Vars(r)

    setupResponse(&w, r)
    if (*r).Method == "OPTIONS" {
        return
    }

    var customer Customer
    var cars []Car

    db.First(&customer, params["id"])
    db.Model(&customer).Related(&cars)

    deleteServicesSqlStatement := `
        DELETE FROM services
        WHERE car_id = $1;`

    for i, car := range cars {
        fmt.Println(i, car.ID)
        err := db.Exec(deleteServicesSqlStatement, car.ID).Error
        if err != nil {
            fmt.Println(err)
        }

    }

    DeleteCarsSqlStatement := `
        DELETE FROM cars
        WHERE customer_id = $1;`

    err := db.Exec(DeleteCarsSqlStatement, params["id"]).Error
    if err != nil {
        fmt.Println(err)
    }

    db.Debug().Unscoped().Delete(&customer)
    json.NewEncoder(w).Encode(&customer)

}


//delete car
func deleteCar(w http.ResponseWriter, r *http.Request) {
    //handle CORS
    setupResponse(&w, r)
    if (*r).Method == "OPTIONS" {
        return
    }

    params := mux.Vars(r)

    var car Car
    db.First(&car, params["id"])

    sqlStatement := `
        DELETE FROM services
        WHERE car_id = $1;`

    err := db.Exec(sqlStatement, params["id"]).Error

    if err != nil {
        fmt.Println(err)
    }

    db.Debug().Unscoped().Delete(&car)
    json.NewEncoder(w).Encode(&car)
}

本篇关于《在 Golang 中如何进行 Gorm 的级联删除操作?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>