Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan

Cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan

PHPz
PHPzasal
2023-11-02 16:37:52591semak imbas

Cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan

Cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan makanan

Dalam masyarakat moden, orang ramai semakin bergantung kepada Internet dan peranti mudah alih untuk memesan makanan. Dengan perkembangan pesat industri bawa pulang dan katering, fungsi carian restoran yang cekap dan tepat amat penting untuk pengalaman pengguna sistem pesanan. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan dan menyediakan contoh kod khusus untuk rujukan.

1. Reka bentuk pangkalan data
Sebelum membangunkan fungsi carian restoran, anda perlu mereka bentuk dan mewujudkan pangkalan data restoran untuk menyimpan maklumat yang berkaitan. Berikut ialah contoh struktur jadual pangkalan data:

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;

Ini ialah jadual restoran ringkas yang mengandungi medan seperti id, nama, alamat, bandar, wilayah, negara, longitud dan latitud. Mengikut keperluan sebenar, bidang yang berkaitan boleh ditambah atau diubah suai mengikut senario perniagaan.

2. Import dependensi
Sebelum memulakan pembangunan, anda perlu mengimport pakej dependensi bahasa Go yang sepadan. Kami menggunakan gin untuk mengendalikan permintaan dan respons HTTP, dan gorm untuk mengendalikan pangkalan data.

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

3. Tulis kod
Berikut ialah contoh kod untuk melaksanakan fungsi carian restoran:

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")
}

Dalam kod di atas, kami mula-mula mentakrifkan struktur Restoran untuk memetakan medan jadual pangkalan data. Kami kemudiannya mewujudkan sambungan ke pangkalan data dan secara automatik memindahkan struktur jadual. Seterusnya, kami mencipta laluan dan menentukan fungsi pengendali untuk permintaan GET.

Dalam fungsi pemprosesan, kami mula-mula mendapat kata kunci parameter kata kunci yang diluluskan oleh pengguna. Kemudian, gunakan kaedah Where gorm untuk melakukan pertanyaan padanan kabur untuk mencari semua restoran yang namanya mengandungi kata kunci. Akhirnya, hasil pertanyaan dikembalikan kepada klien dalam format JSON.

4. Fungsi ujian
Selepas melengkapkan penulisan kod, kita boleh menggunakan alat seperti Posmen untuk menguji sama ada fungsi carian restoran berfungsi dengan baik. Katakan kita memulakan program dan mendengar pada port tempatan 8080. Dengan menghantar permintaan GET ke http://localhost:8080/restaurants/search?keyword=xxx, dengan xxx ialah kata kunci nama restoran yang ingin anda cari, anda boleh mendapatkan hasil carian yang sepadan.

Ringkasan:
Artikel ini memperkenalkan cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan dan menyediakan contoh kod khusus. Dengan mereka bentuk jadual pangkalan data dengan betul dan menggunakan perpustakaan gin dan gorm dalam bahasa Go, kami boleh melaksanakan fungsi carian restoran yang cekap dan tepat dengan mudah. Saya harap artikel ini dapat membantu anda, dan saya ucapkan selamat maju jaya dalam kerja pembangunan anda!

Atas ialah kandungan terperinci Cara menggunakan bahasa Go untuk membangunkan fungsi carian restoran bagi sistem pesanan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn