Go语言开发基于SQLite数据库实现用户表删除接口(五)

背景

上一章
Go语言开发基于SQLite数据库实现用户表修改接口(四)
这一章我们实现用户表的删除接口

代码实现

mapper层

type UserMapper interface {
			DeleteById(id uint64) error
	}
	
type userMapper struct {
}

func (m *userMapper) DeleteById(id uint64) error {
	user := &model.User{}
	err := model.DeleteById(user.TableName(), id)
	if err != nil {
		return err
	}

	return nil
}


ModelTable实现

func DeleteById(tableName string, id uint64) error {

	deleteSQL := fmt.Sprintf("DELETE FROM %s WHERE id = ?", tableName)

	_, err := config.Db.Exec(deleteSQL, id)
	if err != nil {
		return err
	}

	return nil
}


service层

type UserService interface {
	DeleteById(id uint64) error
	}

service实现层

type UserServiceImpl struct {
	m mapper.UserMapper
}

func (u UserServiceImpl) DeleteById(id uint64) error {
	return u.m.DeleteById(id)
}


controller层

type UserController struct {
	UserService service.UserService
}

func (u *UserController) DeleteById(rc *req.Ctx) {
	id := uint64(req.PathParamInt(rc.GinCtx, "id"))
	err := u.UserService.DeleteById(id)
	assert.IsNil(err)
}

这里也有个PathParamInt方法 路径传参,传主键ID

func PathParamInt(g *gin.Context, pm string) int {
	value, _ := strconv.Atoi(g.Param(pm))
	return value
}

接口

在这里插入图片描述

测试

在这里插入图片描述

源码地址

使用Go语言开发基于SQLite数据库实现用户表相关接口项目示例,可进行扩展,拿来即用

参考

代码风格参考的mayfly-go ,SQLite这块是自己实现的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一枚开发小咸鱼

原创不宜,请作者喝杯咖啡吧。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值