内容简介:用adodb驱动查询mssql数据。如果参数带有大括号。就会显示错误:ServeSrs sql db.Prepare error发生意外。 (语法错误或违反访问规则)代码如下:
用adodb驱动查询mssql数据。如果参数带有大括号。就会显示错误:
ServeSrs sql db.Prepare error发生意外。 (语法错误或违反访问规则)
代码如下:
db, err0 := sql.Open("adodb", cfg.Cfg["mssql"]) if err0 != nil { log.Println("ServeSrs sql open error") } else { defer db.Close() stmt1, err0 := db.Prepare(` select top ? * from (select a.[Id], a.[CreateDate],a.[PublisherId],a.[NickName],a.[FileSize],a.[Followed], a.[Readed],a.[FilePath], b.[STitle],row_number() over(order by a.CreateDate desc) as rownumber from [hds12204021_db].[dbo].[Web2019_historylist] a, [hds12204021_db].[dbo].[Web2019_roomlist] b where a.roomid = ? and a.Deleted = 0 and a.roomid=b.id ) temp_row where rownumber>((?-1)*?) `) if err0 != nil { log.Println("ServeSrs sql db.Prepare error" + err0.Error()) } else { defer stmt1.Close() rows, err := stmt1.Query(pagesize, roomid, pageid, pagesize)
然后我们把Prepare格式化的字符串,换个方式搞下:
db, err0 := sql.Open("adodb", cfg.Cfg["mssql"]) if err0 != nil { log.Println("ServeSrs sql open error") } else { defer db.Close() sqlstr := ` select top ` + pagesize + ` * from (select a.[Id], a.[CreateDate],a.[PublisherId],a.[NickName],a.[FileSize],a.[Followed], a.[Readed],a.[FilePath], b.[STitle],row_number() over(order by a.CreateDate desc) as rownumber from [hds12204021_db].[dbo].[Web2019_historylist] a, [hds12204021_db].[dbo].[Web2019_roomlist] b where a.roomid = '` + roomid + `' and a.Deleted = 0 and a.roomid=b.id ) temp_row where rownumber>((?-1)*?) ` //log.Println(sqlstr) stmt1, err0 := db.Prepare(sqlstr) if err0 != nil { log.Println("ServeSrs sql db.Prepare error" + err0.Error()) } else { defer stmt1.Close() rows, err := stmt1.Query(pageid, pagesize)
OK,先自己拼接字符串,再喂给mssql 的adodb驱动就行了。。这坑太奇葩。。
以上所述就是小编给大家介绍的《golang adodb mssql数据库的query格式化奇葩问题》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
编译原理
Alfred V.Aho、Jeffrey D.Ullman、Ravi Sethi / 李建中 / 机械工业出版社 / 2003-8 / 55.00元
《编译原理》作者Alfred V.Aho、Ravi Sethi和Jeffrey D.Ullman是世界著名的计算机 科学家,他们在计算机科学理论、数据库等很多领域都做出了杰出贡献。《编译原理》 是编译领域无可替代的经典著作,被广大计算机专业人士誉为“龙书”。《编译原理》一 直被世界各地的著名高等院校和科研机构(如贝尔实验室、哥伦比亚大学、普 林斯顿大学和斯坦福大学等)广泛用作本科生和研究生编译原理......一起来看看 《编译原理》 这本书的介绍吧!