V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
252748371
V2EX  ›  Go 编程语言

切片如何转数组?

  •  
  •   252748371 · 2019-09-25 16:28:50 +08:00 · 3951 次点击
    这是一个创建于 1889 天前的主题,其中的信息可能已经有所发展或是发生改变。

    切片如何转数组? gorm 的 in 查询不支持切片

    9 条回复    2019-11-15 17:24:12 +08:00
    codehz
        1
    codehz  
       2019-09-25 16:33:39 +08:00
    首先必须长度固定,然后
    var target[5]int
    copy(target[:], source)
    252748371
        2
    252748371  
    OP
       2019-09-25 16:39:43 +08:00
    @codehz
    问题是长度不知道啊
    codehz
        3
    codehz  
       2019-09-25 16:44:31 +08:00
    那就
    target := make([]int, n)
    copy(target[:], source)
    chotow
        4
    chotow  
       2019-09-25 16:50:39 +08:00
    gorm 的 in 查询是支持切片的: http://gorm.io/docs/query.html#Plain-SQL
    xorm 不支持(吐血)
    252748371
        6
    252748371  
    OP
       2019-09-25 17:30:44 +08:00
    @chotow
    哥 帮我看看
    sql: converting argument $4 type: unsupported type []string, a slice of string
    252748371
        7
    252748371  
    OP
       2019-09-25 17:40:10 +08:00
    解决了
    原来不能传指针!
    chotow
        8
    chotow  
       2019-09-27 16:39:08 +08:00
    @kedadiannao220 #5
    xorm Raw SQL 查询的时候,怎么实现 in 传值呢?
    我试了下:db.SQL("select * from test").In("id", []uint64{1, 2, 3}).Find(&ret)
    这样子并不可以
    kedadiannao220
        9
    kedadiannao220  
       2019-11-15 17:24:12 +08:00
    @chotow
    使用 raw sql,就不用再使用 In、where 这些函数了;
    db.SQL("select * from test where id in xxxx"),这样会存在 sql 注入的风险
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3164 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 13:43 · PVG 21:43 · LAX 05:43 · JFK 08:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.