首頁 後端開發 Golang 上門做菜系統的Go語言開發:如何實現使用者消費記錄功能?

上門做菜系統的Go語言開發:如何實現使用者消費記錄功能?

Nov 01, 2023 pm 05:05 PM
go語言開發 上門做菜系統

上門做菜系統的Go語言開發:如何實現使用者消費記錄功能?

上門做菜系統的Go語言開發:如何實現使用者消費記錄功能?

隨著生活水準的提高,人們對飲食的需求也越來越高。越來越多的人開始嘗試自己動手做飯,然而也有不少人因為工作繁忙或懶惰心態無法實現。因此,上門做菜服務應運而生。

而現在的到府做菜服務,一般都是透過網路平台預約下單。顧客透過平台選擇需要的菜色和數量,支付相應的費用後,便可等待上門服務。而在這些服務中,使用者消費記錄功能顯得格外重要。對於服務提供者來講,消費記錄可以幫助他們更好的管理帳務,從而提高營運效率;對於用戶來講,消費記錄可以查看自己近期的消費情況,以便於更好的預估自己的消費能力。

那麼,如何實現上門做菜系統的使用者消費記錄功能呢?下面我們來一起看看。

一、設計資料表

在思考消費記錄功能的實作之前,我們需要先設計對應的資料表。在這個案例中,我們需要設計菜色表、訂單表、訂單詳情表以及消費記錄表。

  • 菜色表設計如下:
CREATE TABLE IF NOT EXISTS `dishes` (
    `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '菜品 ID',
    `name` VARCHAR(50) NOT NULL COMMENT '菜名',
    `image` VARCHAR(100) NOT NULL COMMENT '图片地址',
    `category_id` INT(10) UNSIGNED NOT NULL COMMENT '分类 ID',
    `price` FLOAT(10,2) UNSIGNED NOT NULL COMMENT '价格',
    `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='菜品表';
登入後複製
  • 訂單表設計如下:
CREATE TABLE IF NOT EXISTS `orders` (
    `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '订单 ID',
    `user_id` INT(10) UNSIGNED NOT NULL COMMENT '用户 ID',
    `total_price` FLOAT(10,2) UNSIGNED NOT NULL COMMENT '订单总价',
    `status` TINYINT(1) UNSIGNED NOT NULL DEFAULT '0' COMMENT '订单状态,0:未支付,1:已支付,2:已完成,3:已取消',
    `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单表';
登入後複製
  • 訂單詳情表設計如下:
CREATE TABLE IF NOT EXISTS `order_items` (
    `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '订单详情 ID',
    `order_id` INT(10) UNSIGNED NOT NULL COMMENT '订单 ID',
    `dish_id` INT(10) UNSIGNED NOT NULL COMMENT '菜品 ID',
    `quantity` SMALLINT(5) UNSIGNED NOT NULL COMMENT '数量',
    `price` FLOAT(10,2) UNSIGNED NOT NULL COMMENT '单价',
    `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单详情表';
登入後複製
  • 消費記錄表設計如下:
CREATE TABLE IF NOT EXISTS `consumption_records` (
    `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '消费记录 ID',
    `user_id` INT(10) UNSIGNED NOT NULL COMMENT '用户 ID',
    `order_id` INT(10) UNSIGNED NOT NULL COMMENT '订单 ID',
    `money` FLOAT(10,2) UNSIGNED NOT NULL COMMENT '消费金额',
    `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='消费记录表';
登入後複製

二、實作代碼

在完成資料表的設計後,我們需要使用Go 語言來實現對應的業務邏輯。以下是對應程式碼:

  • 定義結構體:
type ConsumptionRecord struct {
    ID        uint32    `db:"id" json:"id"`
    UserID    uint32    `db:"user_id" json:"user_id"`
    OrderID   uint32    `db:"order_id" json:"order_id"`
    Money     float32   `db:"money" json:"money"`
    CreatedAt time.Time `db:"created_at" json:"created_at"`
    UpdatedAt time.Time `db:"updated_at" json:"updated_at"`
}

type OrderDetail struct {
    ID         uint32    `db:"id" json:"id"`
    OrderID    uint32    `db:"order_id" json:"order_id"`
    DishID     uint32    `db:"dish_id" json:"dish_id"`
    Quantity   uint16    `db:"quantity" json:"quantity"`
    Price      float32   `db:"price" json:"price"`
    CreatedAt  time.Time `db:"created_at" json:"created_at"`
    UpdatedAt  time.Time `db:"updated_at" json:"updated_at"`
    Dish       *Dish     `db:"-" json:"dish"`
}

type Order struct {
    ID         uint32         `db:"id" json:"id"`
    UserID     uint32         `db:"user_id" json:"user_id"`
    TotalPrice float32        `db:"total_price" json:"total_price"`
    Status     OrderStatus    `db:"status" json:"status"`
    CreatedAt  time.Time      `db:"created_at" json:"created_at"`
    UpdatedAt  time.Time      `db:"updated_at" json:"updated_at"`
    Items      []*OrderDetail `db:"-" json:"items"`
}
登入後複製
  • #查詢訂單詳情:
// GetOrderDetailsByOrderIDs 根据订单 ID 列表查询订单详情
func GetOrderDetailsByOrderIDs(DB *sql.DB, orderIDs []uint32) ([]*OrderDetail, error) {
    details := make([]*OrderDetail, 0)

    if len(orderIDs) == 0 {
        return details, nil
    }

    // 拼接查询 SQL
    var placeHolders strings.Builder
    var args []interface{}
    for i, id := range orderIDs {
        if i != 0 {
            placeHolders.WriteString(", ")
        }
        placeHolders.WriteString("?")
        args = append(args, id)
    }

    query := fmt.Sprintf(`
        SELECT
            id, order_id, dish_id, quantity, price, created_at, updated_at
        FROM
            order_items
        WHERE
            order_id IN (%s)
    `, placeHolders.String())

    rows, err := DB.Query(query, args...)
    if err != nil {
        return nil, err
    }
    defer rows.Close()

    // 遍历查询结果,并填充菜品信息到订单详情结构体
    for rows.Next() {
        detail := &OrderDetail{}
        err := rows.Scan(
            &detail.ID, &detail.OrderID, &detail.DishID, &detail.Quantity,
            &detail.Price, &detail.CreatedAt, &detail.UpdatedAt)
        if err != nil {
            return nil, err
        }

        dish, err := GetDishByID(DB, detail.DishID)
        if err != nil {
            return nil, err
        }
        detail.Dish = dish

        details = append(details, detail)
    }

    return details, nil
}
登入後複製
  • 新增消費記錄:
// AddConsumptionRecord 添加消费记录
func AddConsumptionRecord(
    DB *sql.DB,
    userID uint32,
    orderID uint32,
    money float32) error {

    insertQuery := `
        INSERT INTO consumption_records (user_id, order_id, money)
        VALUES (?, ?, ?)
    `
    _, err := DB.Exec(insertQuery, userID, orderID, money)
    if err != nil {
        return err
    }

    return nil
}
登入後複製

三、總結

上面是一個簡單的上門做菜系統中,如何使用Go 語言實作使用者消費記錄功能的案例。透過這個案例,我們可以學習拼接查詢 SQL 的方法、批次查詢的方法、遍歷查詢結果的方法以及插入資料的方法。

整體來看,Go 語言具有簡單、高效、安全等優點,並得到了廣大開發人員的喜愛。相信透過閱讀這個案例,你也能對 Go 語言有更深的了解,同時也希望能夠對你在實現使用者消費記錄功能時有所幫助。

以上是上門做菜系統的Go語言開發:如何實現使用者消費記錄功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1666
14
CakePHP 教程
1425
52
Laravel 教程
1325
25
PHP教程
1273
29
C# 教程
1252
24
如何進行Go語言開發中的單元測試與整合測試 如何進行Go語言開發中的單元測試與整合測試 Jun 29, 2023 am 11:58 AM

如何進行Go語言開發中的單元測試和整合測試摘要:在軟體開發中,單元測試和整合測試是確保程式碼品質和功能穩定性的重要手段。而在Go語言中,也有一套完善的工具支持,使得單元測試和整合測試變得更加簡單和有效率。本文將介紹如何進行Go語言開發中的單元測試和整合測試,並透過一些範例程式碼進行示範。引言Go語言是一種開源的程式語言,因其簡潔而強大的特性而受到越來越多開發者的喜

如何利用Go語言開發點餐系統的會員管理功能 如何利用Go語言開發點餐系統的會員管理功能 Nov 01, 2023 am 09:41 AM

如何利用Go語言開發點餐系統的會員管理功能一、引言隨著行動互聯網的普及,點餐系統成為了餐飲業不可或缺的一部分。而會員管理功能作為點餐系統的重要組成部分,對於提升使用者體驗、增強使用者黏性具有重要作用。本文將介紹如何利用Go語言開發點餐系統的會員管理功能,並提供具體的程式碼範例。二、會員管理功能的需求分析會員註冊:使用者可透過手機號碼、信箱等方式註冊成為會員。會員登

Go語言開發工作專案經驗分享 Go語言開發工作專案經驗分享 Nov 02, 2023 am 09:14 AM

隨著網路的發展,電腦科學領域也迎來了許多全新的程式語言。其中,Go語言以其並發性和簡潔的語法,逐漸成為許多開發者的首選。作為一名從事軟體開發的工程師,我有幸參與了一個基於Go語言的工作項目,並在這個過程中積累了一些寶貴的經驗和教訓。首先,選擇適合的框架和函式庫是至關重要的。在開始專案之前,我們進行了詳細的研究,嘗試了不同的框架和函式庫,最後選擇了Gin框架作為我

Go語言開發小技巧:阿里雲介面對接實作分享 Go語言開發小技巧:阿里雲介面對接實作分享 Jul 05, 2023 pm 11:49 PM

Go語言開發小技巧:阿里雲端介面對接實務分享前言:現如今,雲端運算已成為了企業資訊化建置的核心技術之一,而阿里雲端作為國內知名的雲端運算服務供應商,擁有豐富的雲端產品和服務。本文將分享筆者在使用Go語言對接阿里雲介面時的一些實務經驗,並以程式碼範例的形式進行闡述。一、引進阿里雲GoSDK在使用Go語言對接阿里雲介面之前,首先我們需要引進對應的阿里雲GoSDK,以便

使用Go語言開發跨平台應用程式的優點和挑戰 使用Go語言開發跨平台應用程式的優點和挑戰 Jul 03, 2023 pm 05:25 PM

使用Go語言開發跨平台應用程式的優點和挑戰隨著行動互聯網的迅速發展,跨平台應用程式成為了開發者們的必備技能。 Go語言作為一門簡潔高效、並發性能出色的語言,因其獨特的特性而逐漸受到開發者的青睞。本文將探討使用Go語言開發跨平台應用程式的優點和挑戰,並提供相應的程式碼範例。一、優點1.語言特性齊備:Go語言提供了豐富的標準庫,涵蓋了各種常用功能,如文件操作、網絡通

如何使用Go語言編寫上門做菜系統中的菜色庫存管理模組? 如何使用Go語言編寫上門做菜系統中的菜色庫存管理模組? Nov 01, 2023 am 09:42 AM

如何使用Go語言編寫上門做菜系統中的菜色庫存管理模組?隨著外帶和上門做飯的興起,越來越多的人選擇在家享受美食。作為提供上門做菜服務的平台,菜色庫存管理是不可或缺的一部分。在本文中,將介紹如何使用Go語言編寫上門做菜系統中的菜色庫存管理模組,並提供具體程式碼範例。菜色庫存管理模組的功能主要包括菜色的新增、查詢、修改和刪除。首先,我們需要定義一個菜色的結構體。

如何用Go語言開發一個簡單的線上教育平台 如何用Go語言開發一個簡單的線上教育平台 Nov 20, 2023 pm 03:32 PM

如何用Go語言開發一個簡單的線上教育平台引言:如今,互聯網的發展已經滲透到了各行各業,教育領域也不例外。線上教育平台的出現,使學習變得更加靈活和便捷,得到了廣大學生和家長的青睞。本文將介紹如何使用Go語言開發一個簡單的線上教育平台,包括平台建置、功能開發及資料庫設計等方面的內容。一、平台建置首先,我們需要安裝Go語言開發環境。可從官方網站下載並安裝最新版

如何優化Go語言開發中的網路傳輸安全性 如何優化Go語言開發中的網路傳輸安全性 Jun 29, 2023 am 09:41 AM

如何優化Go語言開發中的網路傳輸安全性隨著網路的快速發展,網路傳輸的安全性變得越來越重要。在Go語言開發中,我們可以採取一些措施來優化網路傳輸的安全性。本文將介紹一些常見的方法和技術來幫助你提升Go語言網路傳輸的安全性。一、使用HTTPS協議HTTPS是基於SSL/TLS協定的安全網路傳輸協議,能夠提供加密和身份驗證的功能,可以有效防止網路傳輸被竊聽和

See all articles