Comment utiliser le langage Go pour écrire le module de gestion des comptes utilisateurs dans le système de cuisine en porte-à-porte ?
Dans la vie moderne et trépidante, de plus en plus de personnes choisissent de résoudre leurs problèmes alimentaires grâce à des services de cuisine à domicile. Pour ce prestataire de services, un système de gestion de compte utilisateur complet et solide est très important. Cet article présentera comment utiliser le langage Go pour écrire un module de gestion de compte utilisateur, visant à aider les fournisseurs de services de cuisine à domicile à mieux gérer les informations de compte des utilisateurs et fournira des exemples de code spécifiques.
1. Créez une table de base de données
Tout d'abord, vous devez créer une table de compte utilisateur pour stocker les informations de compte de l'utilisateur. Les données peuvent être stockées à l'aide de bases de données relationnelles (telles que MySQL, PostgreSQL, etc.) ou de bases de données non relationnelles (telles que MongoDB).
Dans MySQL, vous pouvez utiliser l'instruction SQL suivante pour créer une table de compte utilisateur :
CREATE TABLE user ( id INT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(50) NOT NULL, password VARCHAR(100) NOT NULL, email VARCHAR(100) NOT NULL );
2. Écrire le code Go
Ensuite, nous utilisons le langage Go pour écrire le code d'un module de gestion de compte utilisateur. Tout d'abord, vous devez introduire les packages nécessaires :
package main import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" )
Ensuite, définissez une structure pour représenter le compte utilisateur :
type User struct { ID int Username string Password string Email string }
Ensuite, écrivez quelques fonctions pour implémenter des fonctions spécifiques :
func connectDB() (*sql.DB, error) { db, err := sql.Open("mysql", "username:password@tcp(host:port)/database") if err != nil { return nil, err } return db, nil }
func createUser(user User) error { db, err := connectDB() if err != nil { return err } defer db.Close() _, err = db.Exec("INSERT INTO user (username, password, email) VALUES (?, ?, ?)", user.Username, user.Password, user.Email) if err != nil { return err } return nil }
func getUserByUsername(username string) (User, error) { db, err := connectDB() if err != nil { return User{}, err } defer db.Close() var user User err = db.QueryRow("SELECT id, username, password, email FROM user WHERE username = ?", username). Scan(&user.ID, &user.Username, &user.Password, &user.Email) if err != nil { return User{}, err } return user, nil }
func updateUser(user User) error { db, err := connectDB() if err != nil { return err } defer db.Close() _, err = db.Exec("UPDATE user SET username = ?, password = ?, email = ? WHERE id = ?", user.Username, user.Password, user.Email, user.ID) if err != nil { return err } return nil }
func deleteUser(id int) error { db, err := connectDB() if err != nil { return err } defer db.Close() _, err = db.Exec("DELETE FROM user WHERE id = ?", id) if err != nil { return err } return nil }
3. Code de test
Enfin, vous pouvez écrire quelques codes de test pour vérifier l'exactitude de ces fonctions :
func main() { // 创建用户账户 user := User{ Username: "john", Password: "123456", Email: "john@example.com", } err := createUser(user) if err != nil { fmt.Println(err) return } // 根据用户名查询用户账户 retrievedUser, err := getUserByUsername("john") if err != nil { fmt.Println(err) return } fmt.Println(retrievedUser) // 更新用户账户 retrievedUser.Username = "john2" err = updateUser(retrievedUser) if err != nil { fmt.Println(err) return } // 删除用户账户 err = deleteUser(retrievedUser.ID) if err != nil { fmt.Println(err) return } }
Ce qui précède sont les étapes détaillées et des exemples de codes spécifiques pour utiliser le langage Go pour écrire le module de gestion de compte utilisateur dans le système de cuisson porte-à-porte. . En mettant en œuvre ce module, les prestataires de services de cuisine à domicile peuvent mieux gérer les informations de compte des utilisateurs et offrir une meilleure expérience utilisateur. J'espère que cet article vous aidera !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!