首頁 > 後端開發 > Golang > 如何利用Go語言開發點餐系統的預定餐廳功能

如何利用Go語言開發點餐系統的預定餐廳功能

王林
發布: 2023-11-01 17:18:57
原創
598 人瀏覽過

如何利用Go語言開發點餐系統的預定餐廳功能

如何利用Go語言開發點餐系統的預定餐廳功能,需要具體程式碼範例

餐廳預定功能是現代點餐系統中非常重要的一部分,它可以讓顧客提前預約餐廳的用餐時間,有效避免了等位的情況,提升了顧客的用餐體驗。在本文中,我們將使用Go語言來開發一個簡單的餐廳預定功能。

首先,我們需要建立一個資料庫來儲存餐廳的資訊和預定訂單的資料。我們可以使用MySQL作為資料庫管理系統,建立一個名為"restaurant"的資料庫,並在其中建立兩個表分別為"restaurants"和"reservations"。

restaurants表的架構如下:

CREATE TABLE restaurants (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    address VARCHAR(255) NOT NULL,
    capacity INT NOT NULL,
    available_time_start TIME NOT NULL,
    available_time_end TIME NOT NULL
);
登入後複製

reservations表的架構如下:

CREATE TABLE reservations (
    id INT PRIMARY KEY AUTO_INCREMENT,
    restaurant_id INT NOT NULL,
    guest_name VARCHAR(255) NOT NULL,
    reservation_time DATETIME NOT NULL,
    FOREIGN KEY (restaurant_id) REFERENCES restaurants(id)
);
登入後複製

接下來,我們將使用Go語言來開發點餐系統的預定餐廳功能。首先,我們需要創建一個restaurant結構體來表示餐廳的訊息,包括餐廳的名稱、地址、容量和可用時間段等。

type Restaurant struct {
    ID               int
    Name             string
    Address          string
    Capacity         int
    AvailableTimeStart time.Time
    AvailableTimeEnd   time.Time
}
登入後複製

我們還需要建立一個reservation結構體來表示預定訂單的訊息,包括預定的餐廳ID、顧客姓名和預定時間等。

type Reservation struct {
    ID               int
    RestaurantID     int
    GuestName        string
    ReservationTime  time.Time
}
登入後複製

接下來,我們需要實作一些資料庫操作的函數,包括查詢所有餐廳、查詢可用餐廳、查詢預定訂單、新增預定訂單等。

首先,我們建立一個db變數來儲存資料庫連線。

var db *sql.DB
登入後複製

在main函數中,我們需要開啟資料庫連線。

func main() {
    var err error
    db, err = sql.Open("mysql", "root:password@tcp(localhost:3306)/restaurant")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // 运行HTTP服务器
    http.HandleFunc("/restaurants", getRestaurantsHandler)
    http.HandleFunc("/available-restaurants", getAvailableRestaurantsHandler)
    http.HandleFunc("/reservations", getReservationsHandler)
    http.HandleFunc("/reserve", addReservationHandler)

    log.Fatal(http.ListenAndServe(":8080", nil))
}
登入後複製

下面,我們來實作一些資料庫操作的函數。

首先,查詢所有餐廳的函數如下:

func getRestaurantsHandler(w http.ResponseWriter, r *http.Request) {
    rows, err := db.Query("SELECT * FROM restaurants")
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    var restaurants []Restaurant
    for rows.Next() {
        var restaurant Restaurant
        err := rows.Scan(&restaurant.ID, &restaurant.Name, &restaurant.Address, &restaurant.Capacity, &restaurant.AvailableTimeStart, &restaurant.AvailableTimeEnd)
        if err != nil {
            log.Fatal(err)
        }
        restaurants = append(restaurants, restaurant)
    }

    json.NewEncoder(w).Encode(restaurants)
}
登入後複製

接下來,查詢可用餐廳的函數如下:

func getAvailableRestaurantsHandler(w http.ResponseWriter, r *http.Request) {
    currentTime := time.Now()
    rows, err := db.Query("SELECT * FROM restaurants WHERE available_time_start <= ? AND available_time_end >= ?", currentTime, currentTime)
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    var restaurants []Restaurant
    for rows.Next() {
        var restaurant Restaurant
        err := rows.Scan(&restaurant.ID, &restaurant.Name, &restaurant.Address, &restaurant.Capacity, &restaurant.AvailableTimeStart, &restaurant.AvailableTimeEnd)
        if err != nil {
            log.Fatal(err)
        }
        restaurants = append(restaurants, restaurant)
    }

    json.NewEncoder(w).Encode(restaurants)
}
登入後複製

然後,查詢預定訂單的函數如下:

func getReservationsHandler(w http.ResponseWriter, r *http.Request) {
    rows, err := db.Query("SELECT * FROM reservations")
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    var reservations []Reservation
    for rows.Next() {
        var reservation Reservation
        err := rows.Scan(&reservation.ID, &reservation.RestaurantID, &reservation.GuestName, &reservation.ReservationTime)
        if err != nil {
            log.Fatal(err)
        }
        reservations = append(reservations, reservation)
    }

    json.NewEncoder(w).Encode(reservations)
}
登入後複製

最後,加入預定訂單的函數如下:

func addReservationHandler(w http.ResponseWriter, r *http.Request) {
    var reservation Reservation
    err := json.NewDecoder(r.Body).Decode(&reservation)
    if err != nil {
        http.Error(w, err.Error(), http.StatusBadRequest)
        return
    }

    stmt, err := db.Prepare("INSERT INTO reservations (restaurant_id, guest_name, reservation_time) VALUES (?, ?, ?)")
    if err != nil {
        log.Fatal(err)
    }
    defer stmt.Close()

    _, err = stmt.Exec(reservation.RestaurantID, reservation.GuestName, reservation.ReservationTime)
    if err != nil {
        log.Fatal(err)
    }

    w.WriteHeader(http.StatusOK)
}
登入後複製

透過上述步驟,我們已經完成了使用Go語言開發點餐系統的預定餐廳功能。我們可以使用Postman等工具來測試這些HTTP接口,也可以為前端開發提供對應的資料接口。當然,這只是一個簡單的範例,在實際開發中還需要根據具體需求進行相應的改進和改進。

以上是如何利用Go語言開發點餐系統的預定餐廳功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板