ホームページ >バックエンド開発 >Golang >訪問調理システムの Go 言語開発: ユーザーの消費量記録機能を実装するには?

訪問調理システムの Go 言語開発: ユーザーの消費量記録機能を実装するには?

WBOY
WBOYオリジナル
2023-11-01 17:05:181047ブラウズ

訪問調理システムの Go 言語開発: ユーザーの消費量記録機能を実装するには?

訪問調理システムの Go 言語開発: ユーザーの消費量記録機能を実装するにはどうすればよいですか?

生活水準の向上に伴い、人々の食料に対する需要もますます高まっています。自炊に挑戦する人が増えていますが、仕事が忙しかったり怠けたりして自炊ができない人も多いです。そこで誕生したのが、宅配調理サービスです。

現在、宅配調理サービスはオンラインプラットフォームを通じて予約や注文を行うのが一般的です。顧客はプラットフォームを通じて必要な料理と数量を選択し、対応する料金を支払った後、ドアツードアのサービスを待つことができます。これらのサービスの中でも、特に重要なのがユーザーの消費記録機能です。サービスプロバイダーにとっては、消費記録によりアカウントの管理が改善され、業務効率が向上します。また、ユーザーにとっては、消費記録により最近の消費状況を確認し、消費能力をより正確に見積もることができます。

それでは、訪問調理システムのユーザーの消費量記録機能をどのように実装するのでしょうか?以下を見てみましょう。

1. データ テーブルの設計

消費記録機能の実装を考える前に、まず対応するデータ テーブルを設計する必要があります。この場合、メニュー表、注文表、注文明細表、消費実績表を設計する必要があります。

    #メニュー テーブルは次のように設計されています:
  • 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='消费记录表';

2. 実装コード

データテーブルの完成後 設計が完了したら、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
    }
    Add消費記録:
  • // 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
    }

3. 概要

上記は、Go 言語を使用して、シンプルなドアにユーザー消費記録機能を実装する方法の例です。 -to-door調理システム。このケースを通じて、SQL クエリの結合、バッチ クエリ、クエリ結果のトラバース、データの挿入の方法を学ぶことができます。

全体として、Go 言語にはシンプルさ、効率性、セキュリティという利点があり、大多数の開発者に愛されています。この事例を読むことでGo言語への理解も深まると思いますし、ユーザー消費記録機能を実装する際の参考になれば幸いです。

以上が訪問調理システムの Go 言語開発: ユーザーの消費量記録機能を実装するには?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。