当前位置: 首页 > news >正文

go语言使用model Gorm MySQL查询数据 定时十分钟查询一次 查询十分钟前新建的数据

在Go语言中,使用GORM库与MySQL数据库交互并定时查询数据是常见的需求。以下是一个基本的示例,展示了如何设置定时任务,并使用GORM查询十分钟前新建的数据:

 

首先,你需要安装GORM和MySQL驱动:

 

```bash

go get -u gorm.io/gorm

go get -u gorm.io/driver/mysql

```

 

然后,假设你有一个模型`MyModel`,如下所示:

 

```go

package main

 

import (

 "gorm.io/gorm"

 "time"

)

 

type MyModel struct {

 gorm.Model

 // 其他字段...

}

```

 

接下来,你需要配置GORM连接到MySQL数据库,并设置定时任务:

 

```go

package main

 

import (

 "fmt"

 "gorm.io/driver/mysql"

 "gorm.io/gorm"

 "time"

)

 

func main() {

 // 连接到MySQL数据库

 dsn := "username:password@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"

 db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})

 if err != nil {

  panic("failed to connect database")

 }

 

 // 自动迁移schema

 db.AutoMigrate(&MyModel{})

 

 // 定时任务函数

 ticker := time.NewTicker(10 * time.Minute)

 done := make(chan bool)

 

 go func() {

  for {

   select {

   case <-done:

    return

   case <-ticker.C:

    // 查询十分钟前新建的数据

    tenMinutesAgo := time.Now().Add(-10 * time.Minute)

    var models []MyModel

    db.Where("created_at >= ?", tenMinutesAgo).Find(&models)

 

    // 处理查询结果

    for _, model := range models {

     fmt.Printf("Found model with ID: %d, Created At: %s\n", model.ID, model.CreatedAt)

     // ... 执行其他操作 ...

    }

   }

  }

 }()

 

 // 让主goroutine等待,防止程序退出

 <-make(chan struct{})

}

```

 

在上面的代码中,我们首先使用`gorm.Open`连接到MySQL数据库,并使用`AutoMigrate`自动迁移模型。然后,我们创建了一个`ticker`,它会每隔10分钟触发一次。在`go`函数中,我们监听`ticker`的通道以及一个用于停止定时任务的`done`通道。

 

当`ticker`触发时,我们计算十分钟前的时间点,并使用`Where`和`Find`方法来查询所有在这个时间点之后创建的数据。查询结果会存储在`models`切片中,你可以按照需求处理这些数据。

 

最后,主goroutine通过等待一个永远不会接收的通道来防止程序退出。在实际应用中,你可能需要添加适当的信号处理来优雅地停止定时任务和整个程序。

 

注意:在实际部署环境中,通常不会使用Go的`main`函数来运行定时任务,而是会使用像`cron`这样的系统任务调度器,或者使用专门的任务调度库如`robfig/cron`,或者将定时任务部署到Kubernetes的CronJob中。这样做可以提供更好的可靠性和灵活性。

http://www.lryc.cn/news/358665.html

相关文章:

  • 透视AI技术:探索折射技术在去衣应用中的奥秘
  • 计算机网络工程师需要掌握的知识点
  • Java-Collection家族(List接口)
  • 成绩发布小程序哪个好用?
  • 如何让大模型在智能时代背景下更加先进:一种基于时代特征的探讨
  • Mac 分享 WIFI 后,iPhone 连接 WIFI,但无法上网
  • C语言编程:揭秘平均输入三个数的艺术
  • jvm 触发GC的时机和条件
  • UML用例图
  • fluent UI v9版本Dialog右上角x按钮聚焦问题解决
  • 【SAP HANA 33】前端参数多选情况下HANA如何使用IN来匹配?
  • Go 语言中常量和变量的定义、使用
  • 活动预告|6月13日Apache Flink Meetup·香港站
  • 算法(七)插入排序
  • 抖音太可怕了,我卸载了
  • AI大模型在测试中的深度应用与实践案例
  • OOP一元多项式类(运算符重载)
  • Docker compose 的方式一键部署夜莺
  • 解锁私域流量的奥秘:构建独特的私域生态
  • 在CentOS系统上安装Oracle JDK(华为镜像)
  • 7 步解决Android Studio模拟器切换中文输入
  • 如何搭建B2B2C商城系统?开发语言、功能扩展、优势分析
  • Rust的高效易用日志库—tklog
  • LabVIEW调用外部DLL(动态链接库)
  • Python图形界面(GUI)Tkinter笔记(十六):Radiobutton选项功能按钮(单选按钮)
  • 静态路由原理与配置
  • Android 开机动画的启动过程BootAnimation(基于Android10.0.0-r41)
  • Redis 中的 Zset 数据结构详解
  • Python网页处理与爬虫实战:使用Requests库进行网页数据抓取
  • HOW - vscode 使用指南