V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
richzhu

gorm 如何存数组

  •  
  •   richzhu · Sep 11, 2020 · 7877 views
    This topic created in 2058 days ago, the information mentioned may be changed or developed.

    各位大佬,请问如何使用 gorm 保存切片,下面是我出错的代码

    结构体

    type Node struct {
    	ID     int    `json:"id"`
    	Name   string `json:"name"`
    	Author string `json:"author"`
    	IP   []string `json:"ip"`
    }
    

    Gorm 保存

    ips:=[]string{"1.1.1.1","2.2.2.2","3.3.3.3"}
    body := Node{Name: "testName", Author: "testAuthor", Node: ips}
    if err := DB.Create(&body).Error; err != nil {
    	return false
    }
    

    得到报错

    unsupported data type: &[]
    

    我想存入数据库的数据形式是:

    "1.1.1.1","2.2.2.2","3.3.3.3"
    

    前端发来的数据,只能是一个数组包含着 ip,还不能改。。。 这种情况下,问下大佬们我该咋整 T_T

    10 replies    2020-09-14 08:56:19 +08:00
    zgw0
        1
    zgw0  
       Sep 11, 2020   ❤️ 1
    我之前的做法是转了字符串存起来,然后用的时候再转回数组
    z0wjqnxi
        2
    z0wjqnxi  
       Sep 11, 2020   ❤️ 1
    ``` golang
    type Node struct {
    ...
    IPList ipList `json:"ip" binding:”gt=0,dive,ipv4“ `
    }

    type ipList []string

    // gorm 自定义结构需要实现 Value Scan 两个方法
    // Value 实现方法
    func (p ipList ) Value() (driver.Value, error) {
    return json.Marshal(p)
    }

    // Scan 实现方法
    func (p *ipList ) Scan(data interface{}) error {
    return json.Unmarshal(data.([]byte), &p)
    }


    自定义结构我是这么实现的
    richzhu
        3
    richzhu  
    OP
       Sep 11, 2020
    @zgw0 谢谢老哥,咱俩想的一样,但是我这情况有点特殊,前端发来的数据结构体必须要保持[]string 的类型才可以收到,又不想大改,就没用这个方法

    @z0wjqnxi 感谢大佬,无脑复制您的代码,把 node 改成 ipList 类型后,一下就成功了,爽的不要不要的~
    richzhu
        4
    richzhu  
    OP
       Sep 11, 2020
    sql: Scan error on column index 5, name "node": invalid character '.' after top-level value;

    @z0wjqnxi
    大佬好,使用这个方法之后,不知道为什么,不能读了,读取数据的时候,报上面这个错误
    richzhu
        5
    richzhu  
    OP
       Sep 11, 2020
    @z0wjqnxi 知道了 哈哈,是表中老数据的问题,打扰大佬了
    Yoock
        6
    Yoock  
       Sep 11, 2020 via iPhone
    AfterFind hook
    cszchen
        7
    cszchen  
       Sep 12, 2020 via Android
    用 postgres.jsonb 类型
    reus
        8
    reus  
       Sep 12, 2020
    要对 ip 做查询做索引时你就知错

    应该另外建表,存成多行
    adrianduan
        9
    adrianduan  
       Sep 12, 2020
    不知道你用的是 gorm V1 还是 V2,如果使用的 PostgreSQL 且版本为 V1 的话可以直接定义类型为 pq.StringArray,V2 好像改了 PostgreSQL 的 driver 从 pq 到 pgx,这种写法就不行了
    richzhu
        10
    richzhu  
    OP
       Sep 14, 2020
    @reus 大佬好,请问存成多行是什么意思

    是说新建一张表 2 个字段 app ip
    比如一个 app 名字叫 test 有 3 个 ip,另一个 app 名字是 test1,有 2 个 ip,那表中内容就是

    test 1.1.1.1
    test 2.2.2.2
    test 3.3.3.3
    test1 4.4.4.4
    test1 5.5.5.5

    然后对 ip 字段做索引,是这样嘛?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2479 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 75ms · UTC 07:12 · PVG 15:12 · LAX 00:12 · JFK 03:12
    ♥ Do have faith in what you're doing.