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 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!