三十六、Gin注册功能-检查账号是否存在

一、初始化

1、在cms.go中添加数据库连接方法

func connDB(app *CmsApp) {
	mysqlDB, err := gorm.Open(mysql.Open("root:rootroot@tcp(localhost:3306)/?charset=utf8mb4&parseTime=True&loc=Local"))
	if err != nil {
		panic(err)
	}
	db, err := mysqlDB.DB()
	if err != nil {
		panic(err)
	}
	//最大连接数
	db.SetMaxOpenConns(4)
	//最大空闲连接,一般为最大连接数/2
	db.SetMaxIdleConns(2)
	mysqlDB = mysqlDB.Debug()
	app.db = mysqlDB
}

2、在cms.go中进行初始化数据库连接方法

type CmsApp struct {
	db *gorm.DB
}

func NewCmsApp() *CmsApp {
	app := &CmsApp{}
	connDB(app)
	return app
}

二、完成account表的字段映射model

type Account struct {
	ID        int64     `gorm:"column:id;primaryKey;autoIncrement:true"`
	UserId    string    `gorm:"column:user_id"`
	Password  string    `gorm:"column:password"`
	Nickname  string    `gorm:"column:nickname"`
	CreatedAt time.Time `gorm:"column:created_at"`
	UpdatedAt time.Time `gorm:"column:updated_at"`
}

func (a Account) TableName() string {
    //在数据表中省略了库名,写在了这里因为这样更灵活,方便做分库分表
	table := "cms_account.account"
	return table
}

三、完成account的dao方法

package dao

import (
	"ConnetMain/internal/model"
	"gorm.io/gorm"
)
//声明为gorm的db
type AccountDao struct {
	db *gorm.DB
}
//调用时引入初始化CmsApp.db
func NewAccountDao(db *gorm.DB) *AccountDao {
	return &AccountDao{db: db}
}
//具体实现方法,查询是否存在这个user_id
func (a *AccountDao) IsExist(userID string) (bool, error) {
	var account model.Account
	err := a.db.Where("user_id=?", userID).First(&account).Error
    //返回查询不到错误返回false
	if err == gorm.ErrRecordNotFound {
		return false, err
	}
    //返回错误不为空
	if err != nil {
		return false, err
	}
	return true, nil
}

四、具体调用

在register.go中进行调用IsExist方法

//声明dao包下NewAccountDao
accountDao := dao.NewAccountDao(c.db)
//调用IsExist方法
	isExist, err := accountDao.IsExist(req.UserID)
//发送错误则终止程序
	if err != nil {
		ctx.AbortWithStatusJSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
		return
	}
//返回true则代表能吃查询到相关数据则表示账号已经存在
	if isExist {
		ctx.JSON(http.StatusBadRequest, gin.H{"err": "账号已存在"})
	}

五、实验

相关推荐
学步_技术21 分钟前
Python编码系列—Python组合模式:构建灵活的对象组合
开发语言·python·组合模式
ac-er888834 分钟前
在Flask中处理后台任务
后端·python·flask
ac-er888841 分钟前
Flask中的钩子函数
后端·python·flask
o独酌o44 分钟前
递归的‘浅’理解
java·开发语言
Book_熬夜!1 小时前
Python基础(六)——PyEcharts数据可视化初级版
开发语言·python·信息可视化·echarts·数据可视化
waterHBO1 小时前
R语言 基础笔记
开发语言·笔记·r语言
m0_631270401 小时前
高级c语言(五)
c语言·开发语言
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS在线文档管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
2401_858286111 小时前
53.【C语言】 字符函数和字符串函数(strcmp函数)
c语言·开发语言
Flying_Fish_roe2 小时前
Spring Boot-版本兼容性问题
java·spring boot·后端