go里面报错sql: expected 0 arguments, got 1 问题的解决

之前搞java比较多,用go也是用gorm,xorm这些orm框架,直接拿着sql.db对象去操作数据库比较少,一不小心就掉进一个小坑里面去了,golang操作postgres数据库可以用lib/pg驱动,写查询条件参数的时候例如

select  a from b where c=?

这么写在java里面是没有问题,但是在golang里面不行,会报无效字符,针对postgres数据库写条件参数需要用$1,$2这样的,正确的写法是:

select a from b where c=$1

但是。。。。换到oracle数据库的话,这么写就又不行了,针对oracle如果用?的话会提示:

sql: expected 0 arguments, got 1

针对oracle的正确写法是

select a from b where c=:param1

就是冒号:加参数名称这样的

我靠,用框架的话真不知道还有这些坑啊!

另外虽然说是golang支持变参传递,但是有参数的SQL和无参数的SQL调用的查询方法也得分开,例如

sql:="select * from table1"

args:=nil

如果用db.Query(sql,args) 就不行,必须用db.Query(sql),否则也会报expected 0 arguments,got 1这个错误。

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

peihexian

你的鼓励是我创作的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值