分享
  1. 首页
  2. 文章

golang自己定义数据类型查询与插入postgresql中point数据

gavanwanggw · · 1879 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

golang自己定义数据类型查询与插入postgresql中point数据

详细代码例如以下:

package main
import (
 "bytes"
 "database/sql"
 "database/sql/driver"
 "fmt"
 _ "github.com/lib/pq"
 "strconv"
 "strings"
)
// 自己定义支持类型
type Point struct {
 X float64 `json:"lat"`
 Y float64 `json:"lng"`
}
// 实现driver.Valuer接口
func (p *Point) Value() (driver.Value, error) {
 buf := new(bytes.Buffer)
 fmt.Fprintf(buf, "(%f %f)", p.X, p.Y)
 return buf.Bytes(), nil
}
func (p *Point) String() string {
 return fmt.Sprintf("(%v %v)", p.X, p.Y)
}
// 实现sql.Scanner接口
func (p *Point) Scan(val interface{}) (err error) {
 if bb, ok := val.([]uint8); ok {
 tmp := bb[1 : len(bb)-1]
 coors := strings.Split(string(tmp[:]), ",")
 if p.X, err = strconv.ParseFloat(coors[0], 64); err != nil {
 return err
 }
 if p.Y, err = strconv.ParseFloat(coors[1], 64); err != nil {
 return err
 }
 }
 return nil
}
type Agent struct {
 Id int `json:"id"`
 Name string `json:"name"`
 Code string `json:"code"`
 CS_NO string `json:"cs_no"`
 Channel_id int `json:"channel_id"`
 Address string `json:"address"`
 Coordinate *Point `json:"point"`
}
func main() {
 pgurl := fmt.Sprintf("postgres://%s:%s@%s:%s/%s?sslmode=disable", "postgres", "123456", "localhost", "5432", "people")
 db, err := sql.Open("postgres", pgurl)
 if err != nil {
 panic(fmt.Errorf("连接数据库出错:%v", err))
 }
 querySql := `SELECT * FROM t_agent`
 rows, err := db.Query(querySql)
 if err != nil {
 panic(fmt.Errorf("查询数据出错:%v", err))
 }
 for rows.Next() {
 agent := &Agent{Coordinate: &Point{}}
 err = rows.Scan(&agent.Id,
 &agent.Name, &agent.Code,
 &agent.CS_NO, &agent.Channel_id,
 &agent.Address, agent.Coordinate)
 fmt.Println(agent, err)
 }
 var id int
 err = db.QueryRow("INSERT INTO t_agent (name, code, cs_no, address, coordinate) VALUES(1,ドル2,ドル3,ドル4,ドル5ドル) RETURNING id",
 "test1", "123457", "2", "111", "(12,43)").Scan(&id)
 fmt.Println("id:", id, "err:", err)
}

字段类型须要支持查询的scan时,须要实现sql.Scanner接口
字段类型须要支持插入时,须要实现driver.Valuer接口


有疑问加站长微信联系(非本文作者)

本文来自:博客园

感谢作者:gavanwanggw

查看原文:golang自己定义数据类型查询与插入postgresql中point数据

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
1879 次点击
1 回复 | 直到 2025年05月13日 22:28:24
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏