golang adodb mssql数据库的query格式化奇葩问题

栏目: Go · 发布时间: 5年前

内容简介:用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格式化奇葩问题》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

如何构建敏捷项目管理团队

如何构建敏捷项目管理团队

丽萨·阿金斯 / 徐蓓蓓、白云峰、刘江华 / 电子工业出版社 / 2012-6 / 49.00元

《敏捷项目管理系列丛书•PMI-ACPSM考试指定教材•如何构建敏捷项目管理团队:ScrumMaster、敏捷教练与项目经理的实用指南》结合作者的亲身经历告诉读者如何建立一个高性能的敏捷项目管理团队,以及最终成为一名优秀的敏捷教练。作者将敏捷教练定义为导师、协助者、老师、问题解决者、冲突领航员、协作指挥者,正是这种不同角色之间的细微区别才使敏捷教练的工作富有深度。《敏捷项目管理系列丛书•PMI-A......一起来看看 《如何构建敏捷项目管理团队》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

html转js在线工具
html转js在线工具

html转js在线工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具