


How to implement automatic conversion of position fields to JSON format every time you query a spot table?
Apr 02, 2025 am 11:30 AMGORM efficiently handles Geometry type data: automatic JSON conversion
When operating a database with GORM, it is often necessary to process geometry
-type data, such as converting position
fields in the database (assuming it is geometry
type) into a more easily processed JSON format. This article will introduce a method to automatically convert position
field to JSON every time you query spot
table, without manually converting it every time you query.
Question: Simplify the conversion of Geometry to JSON
In the past, we might have to convert position
field to a JSON string using the st_asgeojson
function alone after each query. To simplify the process, we want GORM to automatically complete this transformation when querying.
Solution: Custom Scanner and Raw SQL Query
To implement automatic JSON conversion in GORM, we can combine custom scanners and Raw
SQL queries:
-
Model definition and custom scanner:
First, define the
spot
model and add a custom scanner forposition
field. This scanner is responsible for converting the byte stream returned by the database into ageojson.geometry
structure. Here, assume that you have introducedgithub.com/paulmach/go.geojson
andgithub.com/tidwall/gjson
libraries.import ( "errors" "github.com/paulmach/go.geojson" "github.com/tidwall/gjson" ) type spot struct { ID uint Position *geojson.Geometry `gorm:"column:position"` } func (g *geojson.Geometry) scan(value interface{}) error { if value == nil { return nil } bytes, ok := value.([]byte) if !ok { return errors.New("failed to scan geometry") } return gjson.Unmarshal(string(bytes), g) // Use gjson for JSON deserialization}
-
Custom query functions:
Create a custom function, use
Raw
SQL query, and use thest_asgeojson
function to convert at the database level.import "gorm.io/gorm" func GetSpot(db *gorm.DB, id uint) (*spot, error) { var spot spot err := db.Raw("SELECT id, ST_AsGeoJSON(position) as position FROM spot WHERE id = ?", id).Scan(&spot).Error if err != nil { return nil, err } return &spot, nil }
-
Data update:
When updating data, you need to convert the
geojson.Geometry
structure back to a JSON string, and then write it to the database using theST_GeomFromGeoJSON
function.import ( "github.com/tidwall/gjson" ) func UpdateSpot(db *gorm.DB, spot *spot) error { jsonStr, err := gjson.Marshal(spot.Position) // Use gjson for JSON serialization if err != nil { return err } return db.Exec("UPDATE spot SET position = ST_GeomFromGeoJSON(?) WHERE id = ?", jsonStr, spot.ID).Error }
Through the above steps, we have realized the automatic conversion of geometry
types to JSON format in GORM, which improves code efficiency and readability. Remember to replace github.com/paulmach/go.geojson
and github.com/tidwall/gjson
for your actual package path. Choosing the right JSON library depends on your project requirements.
The above is the detailed content of How to implement automatic conversion of position fields to JSON format every time you query a spot table?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Contents 1. What is ICN? 2. ICNT latest updates 3. Comparison and economic model between ICN and other DePIN projects and economic models 4. Conclusion of the next stage of the DePIN track At the end of May, ICN (ImpossibleCloudNetwork) @ICN_Protocol announced that it had received strategic investment in NGPCapital with a valuation of US$470 million. Many people's first reaction was: "Has Xiaomi invested in Web3?" Although this was not Lei Jun's direct move, the one who had bet on Xiaomi, Helium, and WorkFusion

As July 2025 approaches, the crypto market is hotly discussing which tokens may bring high returns. Are names like Pi, PEPE and FloppyPepe really worth the risky investment? Potential cryptocurrencies worth paying attention to in July 2025: virtual fire or real gold? As mid-2025, the heat of discussions on high-yield crypto assets continues to heat up. Bitcoin trends and "altcoin season" expectations have attracted investors' attention. Do tokens like PiNetwork, PEPE and FloppyPepe have the potential to bring considerable investment returns? Let's analyze its prospects one by one. Altcoin Market: Can July get what it wants? Against the backdrop of Bitcoin’s expected record of historical highs, the “altcoin season” seems to be brewing. Back

How do novice users choose a safe and reliable stablecoin platform? This article recommends the Top 10 stablecoin platforms in 2025, including Binance, OKX, Bybit, Gate.io, HTX, KuCoin, MEXC, Bitget, CoinEx and ProBit, and compares and analyzes them from dimensions such as security, stablecoin types, liquidity, user experience, fee structure and additional functions. The data comes from CoinGecko, DefiLlama and community evaluation. It is recommended that novices choose platforms that are highly compliant, easy to operate and support Chinese, such as KuCoin and CoinEx, and gradually build confidence through a small number of tests.

Against the backdrop of violent fluctuations in the cryptocurrency market, investors' demand for asset preservation is becoming increasingly prominent. This article aims to answer how to effectively hedge risks in the turbulent currency circle. It will introduce in detail the concept of stablecoin, a core hedge tool, and provide a list of TOP3 stablecoins by analyzing the current highly recognized options in the market. The article will explain how to select and use these stablecoins according to their own needs, so as to better manage risks in an uncertain market environment.

Ripple is redefining the future landscape of the financial industry by applying for a national bank license and promoting XRP’s new role in the crypto economy. Master the latest trends and in-depth observations and seize the trend opportunities. The cryptocurrency ecosystem is in rapid evolution, and Ripple and its digital asset XRP are undoubtedly at the center of the storm. A series of actions carried out in the US banking system are attracting widespread attention. All this development seems to be a real financial drama, gradually beginning! Ripple's banking industry aspirations are roughly the key to Ripple CEO Brad Garlinghouse is no longer content with the boundaries of traditional fintech. As a key step in strategic upgrades, Ripple

This article will discuss the world's mainstream stablecoins and analyze which stablecoins have the risk aversion attribute of "gold substitute" in the market downward cycle (bear market). We will explain how to judge and choose a relatively stable value storage tool in a bear market by comparing the market value, endorsement mechanism, transparency, and comprehensively combining common views on the Internet, and explain this analysis process.

Explore Remittix (RTX), Monero (XMR) and Crypto-Fiat Trends: How these projects shape the future of cryptocurrencies through practicality and community orientation. Remittix, Monero and Cryptocurrency Evolution: What is the hottest speculation? The crypto market is always in a dynamic change, and new and old projects are competing for investors' attention. Currently, Remittix (RTX), Monero (XMR) and crypto-fiat currency directions are becoming the focus of discussion. Let’s find out what driving forces are behind this wave of popularity? Remittix: The emerging token with emerging potential is gradually gaining market attention, and its development trajectory has been compared to the early stages of Bitcoin and Ethereum by some people. "CryptoR

As the market conditions pick up, more and more smart investors have begun to quietly increase their positions in the currency circle. Many people are wondering what makes them take decisively when most people wait and see? This article will analyze current trends through on-chain data to help readers understand the logic of smart funds, so as to better grasp the next round of potential wealth growth opportunities.
