>백엔드 개발 >Golang >Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법은 무엇입니까?

Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법은 무엇입니까?

PHPz
PHPz원래의
2023-11-01 16:36:331151검색

Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법은 무엇입니까?

방문 조리 시스템에서 사용자 피드백 모듈을 작성하기 위해 Go 언어를 사용하는 방법은 무엇입니까?

테이크아웃과 방문판매가 늘어나면서 집에서 맛있는 음식을 즐기는 사용자가 점점 늘어나고 있습니다. 방문 조리 서비스의 경우, 사용자 피드백이 특히 중요하며, 이는 서비스 품질과 사용자 만족도 향상에 도움이 될 수 있습니다. 본 글에서는 Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

  1. 데이터베이스 설계 및 생성

먼저 사용자 피드백 정보를 저장할 데이터베이스를 설계해야 합니다. id(자동 증가 기본 키), userId(사용자 ID), content(피드백 콘텐츠), createTime(생성 시간) 필드를 포함하는 Feedback이라는 테이블이 있다고 가정합니다.

다음 SQL 문을 사용하여 피드백 테이블을 생성합니다.

CREATE TABLE Feedback (

id INT AUTO_INCREMENT PRIMARY KEY,
userId INT NOT NULL,
content TEXT NOT NULL,
createTime TIMESTAMP DEFAULT CURRENT_TIMESTAMP

);

  1. Go 언어 환경 구축

Go 언어 환경이 설치되었고 GOPATH가 설정되었는지 확인하세요.

  1. Go 모듈 만들기

명령줄에서 다음 명령을 실행하여 새 Go 모듈을 만듭니다.

go mod init Feedback

  1. 데이터베이스 연결 만들기

루트 디렉터리에 db라는 파일을 만듭니다. 프로젝트 .go 파일을 복사하고 다음 코드를 추가하세요:

package main

import (

"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"

)

func ConnectDB() (*sql.DB, error) {

db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/feedback")
if err != nil {
    return nil, fmt.Errorf("failed to connect to database: %v", err)
}

err = db.Ping()
if err != nil {
    return nil, fmt.Errorf("failed to ping database: %v", err)
}

return db, nil

}

replace "root:password " ""를 데이터베이스 사용자 이름과 비밀번호로 바꾸고, "feedback"을 생성한 데이터베이스 이름으로 바꾸세요.

  1. 피드백 모델 만들기

프로젝트의 루트 디렉터리에 Feedback.go라는 파일을 만들고 다음 코드를 추가합니다.

package main

import (

"database/sql"
"fmt"
"time"

)

type Feedback struct {

ID        int
UserID    int
Content   string
CreateTime time.Time

}

func InsertFeedback(db sql.DB, 피드백 Feedback) 오류 {

stmt, err := db.Prepare("INSERT INTO feedback(userId, content) VALUES(?, ?)")
if err != nil {
    return fmt.Errorf("failed to prepare insert statement: %v", err)
}
defer stmt.Close()

_, err = stmt.Exec(feedback.UserID, feedback.Content)
if err != nil {
    return fmt.Errorf("failed to execute insert statement: %v", err)
}

return nil

}

func GetFeedbacks(db sql.DB) ([]Feedback, 오류) {

rows, err := db.Query("SELECT * FROM feedback")
if err != nil {
    return nil, fmt.Errorf("failed to execute query: %v", err)
}
defer rows.Close()

feedbacks := make([]*Feedback, 0)
for rows.Next() {
    feedback := &Feedback{}
    err := rows.Scan(&feedback.ID, &feedback.UserID, &feedback.Content, &feedback.CreateTime)
    if err != nil {
        return nil, fmt.Errorf("failed to scan feedback: %v", err)
    }
    feedbacks = append(feedbacks, feedback)
}

return feedbacks, nil

}

여기 A 피드백 구조는 피드백 정보를 표현하기 위해 정의되며, 새로운 피드백을 삽입하고 모든 피드백을 얻기 위한 방법을 제공합니다.

  1. HTTP 인터페이스 만들기

프로젝트의 루트 디렉터리에 main.go라는 파일을 만들고 다음 코드를 추가합니다.

package main

import (

"encoding/json"
"log"
"net/http"

)

func main() {

db, err := ConnectDB()
if err != nil {
    log.Fatalf("failed to connect to database: %v", err)
}
defer db.Close()

http.HandleFunc("/feedback", func(w http.ResponseWriter, r *http.Request) {
    switch r.Method {
    case http.MethodGet:
        feedbacks, err := GetFeedbacks(db)
        if err != nil {
            log.Printf("failed to get feedbacks: %v", err)
            http.Error(w, "Internal server error", http.StatusInternalServerError)
            return
        }

        json.NewEncoder(w).Encode(feedbacks)
    case http.MethodPost:
        var feedback Feedback
        err := json.NewDecoder(r.Body).Decode(&feedback)
        if err != nil {
            log.Printf("failed to decode feedback: %v", err)
            http.Error(w, "Bad request", http.StatusBadRequest)
            return
        }

        err = InsertFeedback(db, &feedback)
        if err != nil {
            log.Printf("failed to insert feedback: %v", err)
            http.Error(w, "Internal server error", http.StatusInternalServerError)
            return
        }

        w.WriteHeader(http.StatusCreated)
    default:
        http.Error(w, "Method not allowed", http.StatusMethodNotAllowed)
    }
})

log.Println("Server listening on :8000")
log.Fatal(http.ListenAndServe(":8000", nil))

}

여기에 /feedback이라는 HTTP 인터페이스가 생성되는데, 이는 모든 피드백 정보를 얻기 위한 GET 메서드와 새로운 피드백 정보를 삽입하기 위한 POST 메서드를 지원합니다.

  1. 서비스 시작

명령줄에서 다음 명령을 실행하여 서비스를 시작합니다.

go run main.go

이제 Postman 또는 기타 HTTP 클라이언트를 사용하여 GET 및 POST 요청을 보내 테스트할 수 있습니다. Door to Door 서비스 이제 접시 시스템의 사용자 피드백 모듈을 사용할 수 있습니다.

위 단계를 통해 Go 언어를 사용하여 방문 조리 시스템에서 간단한 사용자 피드백 모듈을 작성했습니다. 실제 필요에 따라 확장하고 최적화할 수 있습니다. 이 기사가 도움이 되기를 바랍니다!

위 내용은 Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.