[Go] gorm执行原生sql语句

当有复杂sql语句的时候,我们需要执行原生sql语句,这样更加方便

比如下面的这条sql语句

复制代码
//查询每天条数
type EveryDayNum struct {
    Day string `json:"day"`
    Num int64  `json:"num"`
}

func CountVisitorsEveryDay(toId string) []EveryDayNum {
    var results []EveryDayNum
    DB.Raw("select DATE_FORMAT(updated_at,'%Y-%m-%d') as day ,"+
        "count(*) as num from visitor where to_id=? group by day order by day desc limit 30",
        toId).Scan(&results)
    return results
}
复制代码

只需要拿着数据库对象去.Raw(原生sql).Scan()就可以了

Scan的参数是一个结构体引用,所以一定要定义好结构体接收数据才行

 

posted @   唯一客服系统开发笔记  阅读(1698)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2019-10-17 [Linux] SSH隧道本地端口转发访问远程服务中的数据库
2019-10-17 [PHP] vscode配置SFTP扩展同步文件
2019-10-17 [PHP] PHP-FPM的access日志error日志和slow日志
2018-10-17 [PHP]算法-最长公共子串的PHP实现
点击右上角即可分享
微信分享提示
1
chat with us