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