Home Backend Development Golang Detailed examples of query operations of Golang GORM

Detailed examples of query operations of Golang GORM

Apr 03, 2023 am 11:50 AM

Golang is a relatively new programming language. Its birth makes the development of web applications easier. The superiority of Golang lies in its concurrency mechanism and concise language syntax. GORM is an ORM (Object Relational Mapping) library in Golang. It is similar to ORMs in other languages ​​and can implement object-oriented database operations, making database additions, deletions, modifications and queries simpler and clearer. In this article, we will mainly introduce the query operations of Golang GORM.

1. Foreword

When using Golang GORM for query operations, we need to import the GORM library first, and then set the corresponding database information, for example:

import (
    "gorm.io/gorm"
    "gorm.io/driver/mysql"
)

dsn := "root:password@tcp(127.0.0.1:3306)/database?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
Copy after login

Here we use mysql database, and set the corresponding database connection information. After importing the GORM library, we need to define the corresponding data structure, for example:

type User struct {
  ID        int
  Name      string
  Age       int
  Email     string
  CreatedAt time.Time
}
Copy after login

Here we define a User structure, including ID, Name, Age, Email and CreatedAt fields, where ID is automatically Incremental primary key field.

2. Query method

  1. Find a single record

In Golang GORM, we can use the Find method to query a record, for example:

var user User
db.Find(&user, 1) // 查询主键为1的记录
Copy after login

Here we define a user variable and use the Find method to query the records with a primary key of 1. The queried data will be saved in the user variable.

  1. Find multiple records

In Golang GORM, we can use the Find method to query multiple records, for example:

var users []User
db.Find(&users) // 查询所有的记录
Copy after login

Here we define A users slice variable and use the Find method to query all records. All queried data will be saved in the users array.

  1. Conditional query

In Golang GORM, we can use the Where method to perform conditional query, for example:

var users []User
db.Where("age > ?", 18).Find(&users) // 查询年龄大于18的所有记录
Copy after login

Here we query the age through the Where method All records greater than 18 are stored in the users slice variable.

  1. Fuzzy query

In Golang GORM, we can use the Like method to perform fuzzy query, for example:

var users []User
db.Where("name LIKE ?", "%john%").Find(&users) // 查询名字中包含“john”的记录
Copy after login

Here we use the Where method Fuzzy query, query records whose names contain "john" and save them in the users slice variable.

  1. IN conditional query

In Golang GORM, we can use the In method to perform IN conditional query, for example:

var users []User
db.Where("name IN ?", []string{"john", "mary", "bob"}).Find(&users) // 查询名字为john、mary、bob的所有记录
Copy after login

Here we use the Where method An IN conditional query was performed to query all records named john, mary, and bob, and stored in the users slice variable.

  1. BETWEEN condition query

In Golang GORM, we can use the Between method to perform BETWEEN condition query, for example:

var users []User
db.Where("age BETWEEN ? AND ?", 18, 30).Find(&users) // 查询年龄在18到30岁之间的所有记录
Copy after login

Here we use the Where method A BETWEEN conditional query was performed to query all records between the ages of 18 and 30 and save them in the users slice variable.

3. Summary

The above is the query operation method of Golang GORM. Through the query operation of Golang GORM, we can easily implement the ORM operation based on Golang, making the addition, deletion, modification and query of the database simpler and clearer. Of course, in practical applications, we still need to apply it flexibly according to specific business needs.

The above is the detailed content of Detailed examples of query operations of Golang GORM. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do you use the pprof tool to analyze Go performance? How do you use the pprof tool to analyze Go performance? Mar 21, 2025 pm 06:37 PM

The article explains how to use the pprof tool for analyzing Go performance, including enabling profiling, collecting data, and identifying common bottlenecks like CPU and memory issues.Character count: 159

How do you write unit tests in Go? How do you write unit tests in Go? Mar 21, 2025 pm 06:34 PM

The article discusses writing unit tests in Go, covering best practices, mocking techniques, and tools for efficient test management.

How do I write mock objects and stubs for testing in Go? How do I write mock objects and stubs for testing in Go? Mar 10, 2025 pm 05:38 PM

This article demonstrates creating mocks and stubs in Go for unit testing. It emphasizes using interfaces, provides examples of mock implementations, and discusses best practices like keeping mocks focused and using assertion libraries. The articl

How can I define custom type constraints for generics in Go? How can I define custom type constraints for generics in Go? Mar 10, 2025 pm 03:20 PM

This article explores Go's custom type constraints for generics. It details how interfaces define minimum type requirements for generic functions, improving type safety and code reusability. The article also discusses limitations and best practices

Explain the purpose of Go's reflect package. When would you use reflection? What are the performance implications? Explain the purpose of Go's reflect package. When would you use reflection? What are the performance implications? Mar 25, 2025 am 11:17 AM

The article discusses Go's reflect package, used for runtime manipulation of code, beneficial for serialization, generic programming, and more. It warns of performance costs like slower execution and higher memory use, advising judicious use and best

How can I use tracing tools to understand the execution flow of my Go applications? How can I use tracing tools to understand the execution flow of my Go applications? Mar 10, 2025 pm 05:36 PM

This article explores using tracing tools to analyze Go application execution flow. It discusses manual and automatic instrumentation techniques, comparing tools like Jaeger, Zipkin, and OpenTelemetry, and highlighting effective data visualization

How do you use table-driven tests in Go? How do you use table-driven tests in Go? Mar 21, 2025 pm 06:35 PM

The article discusses using table-driven tests in Go, a method that uses a table of test cases to test functions with multiple inputs and outcomes. It highlights benefits like improved readability, reduced duplication, scalability, consistency, and a

How do you specify dependencies in your go.mod file? How do you specify dependencies in your go.mod file? Mar 27, 2025 pm 07:14 PM

The article discusses managing Go module dependencies via go.mod, covering specification, updates, and conflict resolution. It emphasizes best practices like semantic versioning and regular updates.

See all articles