MySQL と Go 言語を使用して単純なショッピング カート機能を開発する方法
電子商取引の台頭により、ショッピング カートは必要な機能モジュールになりました。この記事では、MySQL と Go 言語を使用して簡単なショッピング カート機能を開発する方法と、具体的なコード例を紹介します。
1. 準備
まず、ユーザーのショッピング カートに関連する情報を保存するための MySQL データベースを構築する必要があります。 MySQL に「shopping_cart」という名前のデータベースを作成し、その中に「cart_items」という名前のデータ テーブルを作成します。 "cart_items" テーブルの構造は次のとおりです。
CREATE TABLE Cart_items (
id INT AUTO_INCREMENT PRIMARY KEY, user_id INT NOT NULL, product_id INT NOT NULL, quantity INT NOT NULL, price DECIMAL(10, 2) NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
このうち、id フィールドは自動インクリメントされる主キーであり、 user_id フィールドはユーザー ID と product_id を格納するために使用されます。フィールドは製品 ID を格納するために使用され、数量フィールドは購入数量を格納するために使用され、価格フィールドは製品価格を格納するために使用され、created_at フィールドは次の目的で使用されます。作成時間を保存します。
2. Go 言語のコード例
次は、Go 言語で書かれた単純なショッピング カート関数のコード例です。
package main
import (
"database/sql" "fmt" _ "github.com/go-sql-driver/mysql"
)
type CartItem struct {
ID int UserID int ProductID int Quantity int Price float32 CreatedAt string
}
func main() {
// 连接数据库 db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/shopping_cart") checkError(err) defer db.Close() // 创建购物车项 item := &CartItem{ UserID: 1, ProductID: 1, Quantity: 2, Price: 19.99, } createCartItem(db, item) // 获取购物车项列表 items, err := getCartItems(db, item.UserID) checkError(err) for _, item := range items { fmt.Println(item) }
}
func createCartItem (db sql.DB, item CartItem) {
stmt, err := db.Prepare("INSERT INTO cart_items(user_id, product_id, quantity, price) VALUES(?, ?, ?, ?)") checkError(err) defer stmt.Close() _, err = stmt.Exec(item.UserID, item.ProductID, item.Quantity, item.Price) checkError(err)
}
func getCartItems(db *sql.DB, userID int) ([]CartItem, error) {
rows, err := db.Query("SELECT * FROM cart_items WHERE user_id = ?", userID) if err != nil { return nil, err } defer rows.Close() var items []CartItem for rows.Next() { var item CartItem err := rows.Scan(&item.ID, &item.UserID, &item.ProductID, &item.Quantity, &item.Price, &item.CreatedAt) if err != nil { return nil, err } items = append(items, item) } return items, nil
}
func checkError(err error) {
if err != nil { panic(err) }
}
上記のコードでは、最初に sql.Open 関数を使用して、 MySQLデータベース。次に、ショッピング カートのアイテム情報を表す CartItem 構造体を定義しました。 createCartItem 関数は、ショッピング カートのアイテムを作成し、データベースに挿入するために使用されます。 getCartItems 関数は、指定されたユーザーのショッピング カートのアイテム リストをクエリするために使用されます。最後に、createCartItem 関数と getCartItems 関数を呼び出して、ショッピング カート関数を示します。
3. 概要
上記の手順により、MySQL と Go 言語を使用した簡単なショッピング カート機能の開発に成功し、具体的なコード例を提供しました。この例は、開発者が MySQL と Go 言語を使用してショッピング カート機能を実装し、実際のニーズに応じて機能を拡張および最適化する方法をより深く理解するのに役立ちます。
以上がMySQLとGo言語を使った簡単なショッピングカート機能の開発方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。