방문 조리 시스템에서 사용자 피드백 모듈을 작성하기 위해 Go 언어를 사용하는 방법은 무엇입니까?
테이크아웃과 방문판매가 늘어나면서 집에서 맛있는 음식을 즐기는 사용자가 점점 늘어나고 있습니다. 방문 조리 서비스의 경우, 사용자 피드백이 특히 중요하며, 이는 서비스 품질과 사용자 만족도 향상에 도움이 될 수 있습니다. 본 글에서는 Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.
먼저 사용자 피드백 정보를 저장할 데이터베이스를 설계해야 합니다. 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
);
Go 언어 환경이 설치되었고 GOPATH가 설정되었는지 확인하세요.
명령줄에서 다음 명령을 실행하여 새 Go 모듈을 만듭니다.
go mod init Feedback
루트 디렉터리에 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"을 생성한 데이터베이스 이름으로 바꾸세요.
프로젝트의 루트 디렉터리에 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 피드백 구조는 피드백 정보를 표현하기 위해 정의되며, 새로운 피드백을 삽입하고 모든 피드백을 얻기 위한 방법을 제공합니다.
프로젝트의 루트 디렉터리에 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 메서드를 지원합니다.
명령줄에서 다음 명령을 실행하여 서비스를 시작합니다.
go run main.go
이제 Postman 또는 기타 HTTP 클라이언트를 사용하여 GET 및 POST 요청을 보내 테스트할 수 있습니다. Door to Door 서비스 이제 접시 시스템의 사용자 피드백 모듈을 사용할 수 있습니다.
위 단계를 통해 Go 언어를 사용하여 방문 조리 시스템에서 간단한 사용자 피드백 모듈을 작성했습니다. 실제 필요에 따라 확장하고 최적화할 수 있습니다. 이 기사가 도움이 되기를 바랍니다!
위 내용은 Go 언어를 사용하여 방문 조리 시스템에서 사용자 피드백 모듈을 작성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!