如何利用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中文網其他相關文章!