golang sqlx包db.Select查询查不到数据

项目场景:

使用golang数据库操作第三方包sqlx的时候,执行一个SELECT查询时,发现查不到数据,各个软件版本如下:

innodb:8.0.16
sqlx:v1.3.4
go-sql-driver/mysql:v1.6.0
golang:1.16.3

问题描述

下面三条语句直接在MySQL终端可以查询到数据,db.Select查询不到数据:

SELECT * FROM xxx WHERE start_time IS NULL AND ip = ?; # sqlx db.Select查不到数据,MYSQL直接查询可以查到3条
SELECT * FROM xxx WHERE ip = ? AND start_time IS NULL; # sqlx db.Select查不到数据,MYSQL直接查询可以查到3条
SELECT * FROM xxx WHERE ip = ? AND (start_time IS NULL); # sqlx db.Select查不到数据,MYSQL直接查询可以查到3条

其中,start_time为datetime类型,默认值为NULL。

原因分析:

sqlx db.Select在查询的时候,如果字段的默认值为NULL,查询时条件中带“某字段 IS NULL”则会查询不到数据。所以避免踩坑数据库的字段不要默认为NULL,尽量都设置默认值,db.Select查询条件的WHERE中不要带查询"IS NULL"的语句。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

空间法则

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值