首頁  >  文章  >  後端開發  >  如何使用Go語言編寫上門做菜系統中的使用者收藏夾管理模組?

如何使用Go語言編寫上門做菜系統中的使用者收藏夾管理模組?

王林
王林原創
2023-11-01 11:18:20798瀏覽

如何使用Go語言編寫上門做菜系統中的使用者收藏夾管理模組?

如何使用Go語言編寫上門做菜系統中的使用者收藏管理模組?

作為一種快速流行的程式語言,Go語言在Web開發領域中表現出色。本文將介紹如何使用Go語言編寫上門做菜系統中的使用者收藏夾管理模組,並提供具體程式碼範例。

  1. 設計資料庫模型

首先,我們需要設計使用者收藏夾的資料庫模型。假設使用者可以收藏多個菜品,我們可以設計兩張表:使用者表和收藏夾表。

使用者表可以包含以下欄位:

  • 使用者ID(ID)
  • #使用者名稱(Username)
  • 密碼(Password)
  • 建立時間(CreatedAt)
  • 更新時間(UpdatedAt)

#收藏表可以包含以下欄位:

  • 收藏ID( ID)
  • 菜ID(DishID)
  • 使用者ID(UserID)
  • 建立時間(CreatedAt)
  • 更新時間(UpdatedAt)
  1. 建立資料庫連線

在Go語言中,我們可以使用第三方函式庫如Gorm來操作資料庫。首先,需要設定資料庫連接,並建立相關表。

package main

import (
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/mysql"
)

var db *gorm.DB

func init() {
    // 创建数据库连接
    var err error
    db, err = gorm.Open("mysql", "username:password@tcp(localhost:3306)/database?charset=utf8mb4&parseTime=True&loc=Local")
    if err != nil {
        panic(err)
    }

    // 创建相关表
    db.AutoMigrate(&User{}, &Favorite{})
}

func main() {
    defer db.Close()

    // 进行其他操作
}
  1. 定義模型和關聯

在Go語言中,我們需要定義模型來對應資料庫表。以下是User和Favorite兩個模型的定義。

type User struct {
    ID        uint   `gorm:"primary_key"`
    Username  string `gorm:"unique"`
    Password  string
    CreatedAt time.Time
    UpdatedAt time.Time
}

type Favorite struct {
    ID        uint   `gorm:"primary_key"`
    UserID    uint
    DishID    uint
    CreatedAt time.Time
    UpdatedAt time.Time

    User    User
    Dish    Dish
}
  1. 實現收藏夾管理功能

為了實現收藏夾管理功能,我們可以定義一些相關接口,如添加收藏夾、刪除收藏夾、獲取用戶收藏夾列表等。

// 添加收藏夹
func AddFavorite(userID uint, dishID uint) error {
    favorite := Favorite{
        UserID:    userID,
        DishID:    dishID,
        CreatedAt: time.Now(),
        UpdatedAt: time.Now(),
    }

    err := db.Create(&favorite).Error
    if err != nil {
        return err
    }

    return nil
}

// 删除收藏夹
func DeleteFavorite(userID uint, dishID uint) error {
    err := db.Where("user_id = ? AND dish_id = ?", userID, dishID).Delete(&Favorite{}).Error
    if err != nil {
        return err
    }

    return nil
}

// 获取用户收藏夹列表
func GetFavoriteList(userID uint) ([]Favorite, error) {
    var favorites []Favorite
    err := db.Where("user_id = ?", userID).Find(&favorites).Error
    if err != nil {
        return nil, err
    }

    return favorites, nil
}

以上範例程式碼可以實現新增、刪除和取得使用者收藏夾的功能。

綜上所述,本文介紹如何使用Go語言撰寫上門做菜系統中的使用者收藏管理模組。透過定義資料庫模型、建立資料庫連接,並實現相應的功能,我們可以輕鬆地管理使用者的收藏夾。希望這篇文章能幫助你,祝程式愉快!

以上是如何使用Go語言編寫上門做菜系統中的使用者收藏夾管理模組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn