之前搞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这个错误。