Go 言語を使用して注文システムのレストラン予約機能を開発する方法。具体的なコード例が必要です。
レストラン予約機能は、注文システムの非常に重要な部分です。最新の注文システム。顧客は事前にレストランでの食事時間を予約できるため、テーブルを待つことが効果的に回避され、顧客の食事体験が向上します。今回はGo言語を使って簡単なレストラン予約機能を開発していきます。
まず、レストラン情報と予約注文データを保存するデータベースを作成する必要があります。 MySQL をデータベース管理システムとして使用し、「restaurant」という名前のデータベースを作成し、その中に「restaurants」と「reservations」という 2 つのテーブルを作成します。
レストラン テーブルの構造は次のとおりです:
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 );
予約テーブルの構造は次のとおりです:
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 言語を使用して開発します。オーダーシステムのレストラン予約機能。まず、レストランの名前、住所、収容人数、利用可能な時間帯などのレストランの情報を表すレストラン構造を作成する必要があります。
type Restaurant struct { ID int Name string Address string Capacity int AvailableTimeStart time.Time AvailableTimeEnd time.Time }
予約したレストラン 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 中国語 Web サイトの他の関連記事を参照してください。