分享
golang adodb mssql数据库的query格式化奇葩问题
毛毛v5 · · 1326 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
用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驱动就行了。。这坑太奇葩。。
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1326 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
用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驱动就行了。。这坑太奇葩。。