码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • go gin gorm连接postgres postgis输出geojson


    go gin gorm连接postgres postgis输出geojson

    1. 技术环境

            go-gin-gorm

            postgres-postgis

            go vscode环境安装-智能提示配置

    2. 简单实现代码

            思路就是:采用原生sql实现查询、更新等,采用gorm的raw来执行sql语句

    1. package main
    2. import (
    3. "fmt"
    4. "net/http"
    5. "github.com/gin-gonic/gin"
    6. "gorm.io/driver/postgres"
    7. "gorm.io/gorm"
    8. )
    9. // 前提是在postgres中安装好postgis插件
    10. func main() {
    11. dsn := "host=localhost user=postgres password=5241 dbname=test port=5432 sslmode=disable TimeZone=Asia/Shanghai"
    12. db, _ := gorm.Open(postgres.New(postgres.Config{
    13. DSN: dsn,
    14. PreferSimpleProtocol: true,
    15. }), &gorm.Config{})
    16. r := gin.Default()
    17. r.GET("/data/:table_name", func(c *gin.Context) {
    18. table_name := c.Param("table_name")
    19. // 从postgis中利用 ST 函数 获得的结果,以string返回,然后前端进行解析即可
    20. var result string
    21. if db.Migrator().HasTable(table_name) {
    22. sqls := fmt.Sprintf("select json_build_object('type', 'FeatureCollection', 'name', '%s', 'features', json_agg(ST_ASGeoJSON(t.*)::json)) from %s AS t", table_name, table_name)
    23. db.Raw(sqls).Scan(&result)
    24. }
    25. fmt.Printf("%q", result)
    26. c.JSON(http.StatusOK, gin.H{
    27. "message": "ok",
    28. "data": result,
    29. })
    30. })
    31. r.Run(":8080")
    32. }

    3. 结果图片

            

  • 相关阅读:
    南怀瑾:“心静出贵人”,中年后这三个地方静,一切都会越来越顺!
    token过期?页面如何实现无感刷新?
    Linux:firewalld防火墙-介绍(1)
    【电力系统】含电热联合系统的微电网运行优化附matlab代码和复现论文
    Nacos - 支持PostgreSQL
    学习笔记-数据结构-线性表(2024-04-21)
    Web前端,HTML表格相关标签和属性,在网页中表格结构的显示
    图书馆座位预约管理系统毕业设计,图书馆座位管理系统设计与实现,图书馆座位预约系统毕业论文毕设作品参考
    变量、流程控制与游标(MySQL)
    vue 代理
  • 原文地址:https://blog.csdn.net/LEILEI18A/article/details/132607759
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号