>백엔드 개발 >Golang >Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법

Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법

PHPz
PHPz원래의
2023-11-02 16:37:52625검색

Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법

Go 언어를 사용하여 음식 주문 시스템의 레스토랑 검색 기능을 개발하는 방법

현대 사회에서 사람들은 음식 주문을 위해 인터넷과 모바일 장치에 점점 더 의존하고 있습니다. 테이크아웃 및 케이터링 산업의 급속한 발전으로 인해 효율적이고 정확한 레스토랑 검색 기능은 주문 시스템의 사용자 경험에 특히 중요합니다. 이 기사에서는 Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법을 소개하고 참조할 수 있는 구체적인 코드 예제를 제공합니다.

1. 데이터베이스 설계
맛집 검색 기능을 개발하기 전에 먼저 관련 정보를 저장할 맛집 데이터베이스를 설계하고 구축해야 합니다. 다음은 데이터베이스 테이블 구조의 예입니다.

CREATE TABLE `restaurants` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `address` varchar(255) NOT NULL,
  `city` varchar(255) NOT NULL,
  `province` varchar(255) NOT NULL,
  `country` varchar(255) NOT NULL,
  `latitude` float(10,6) NOT NULL,
  `longitude` float(10,6) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

이것은 ID, 이름, 주소, 도시, 도, 국가, 경도 및 위도와 같은 필드를 포함하는 단순화된 레스토랑 테이블입니다. 실제 필요에 따라 비즈니스 시나리오에 따라 관련 필드를 추가하거나 수정할 수 있습니다.

2. 종속성 가져오기
개발을 시작하기 전에 먼저 해당 Go 언어 종속성 패키지를 가져와야 합니다. gin을 사용하여 HTTP 요청 및 응답을 처리하고 gorm을 사용하여 데이터베이스를 운영합니다.

go get -u github.com/gin-gonic/gin
go get -u gorm.io/gorm
go get -u gorm.io/driver/mysql

3. 코드 작성
다음은 레스토랑 검색 기능을 구현하는 샘플 코드입니다.

package main

import (
    "fmt"
    "github.com/gin-gonic/gin"
    "gorm.io/driver/mysql"
    "gorm.io/gorm"
    "net/http"
)

type Restaurant struct {
    ID        uint   `gorm:"primaryKey"`
    Name      string `gorm:"column:name"`
    Address   string `gorm:"column:address"`
    City      string `gorm:"column:city"`
    Province  string `gorm:"column:province"`
    Country   string `gorm:"column:country"`
    Latitude  float64 `gorm:"column:latitude"`
    Longitude float64 `gorm:"column:longitude"`
}

func main() {
    dsn := "<mysql connection string>"
    db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
    if err != nil {
        panic("Failed to connect to database")
    }

    db.AutoMigrate(&Restaurant{})

    router := gin.Default()

    router.GET("/restaurants/search", func(c *gin.Context) {
        keyword := c.Query("keyword")

        var restaurants []Restaurant
        result := db.Where("name LIKE ?", fmt.Sprintf("%%%s%%", keyword)).Find(&restaurants)
        if result.Error != nil {
            c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to retrieve restaurants"})
            return
        }

        c.JSON(http.StatusOK, restaurants)
    })

    router.Run(":8080")
}

위 코드에서는 먼저 레스토랑 구조를 정의하여 데이터베이스 테이블 필드를 매핑합니다. 그런 다음 데이터베이스에 대한 연결을 설정하고 테이블 구조를 자동으로 마이그레이션했습니다. 다음으로 경로를 생성하고 GET 요청에 대한 핸들러 함수를 정의했습니다.

처리 함수에서는 먼저 사용자가 전달한 키워드 매개변수 키워드를 가져옵니다. 그런 다음 gorm의 Where 메소드를 사용하여 퍼지 일치 쿼리를 수행하여 이름에 키워드가 포함된 모든 레스토랑을 찾습니다. 마지막으로 쿼리 결과는 JSON 형식으로 클라이언트에 반환됩니다.

4. 테스트 기능
코드 작성이 완료된 후 Postman과 같은 도구를 사용하여 레스토랑 검색 기능이 제대로 작동하는지 테스트할 수 있습니다. 프로그램을 시작하고 로컬 포트 ​​8080에서 수신 대기한다고 가정합니다. http://localhost:8080/restaurants/search?keyword=xxx(여기서 xxx는 검색하려는 레스토랑 이름의 키워드)로 GET 요청을 보내면 해당 검색결과를 얻을 수 있습니다.

요약:
이 글에서는 Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 데이터베이스 테이블을 적절하게 설계하고 Go 언어의 gin 및 gorm 라이브러리를 사용함으로써 효율적이고 정확한 레스토랑 검색 기능을 쉽게 구현할 수 있습니다. 이 글이 여러분에게 도움이 되기를 바라며, 여러분의 개발 작업에 행운이 있기를 바랍니다!

위 내용은 Go 언어를 사용하여 주문 시스템의 레스토랑 검색 기능을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.