Use an ORM
This page documents the preview version (v2.21). Preview includes features under active development and is for development and testing only. For production, use the stable version (v2024.1). To learn more, see Versioning.
GORM is the ORM library for Golang.
CRUD operations
Learn how to establish a connection to a YugabyteDB database and begin basic CRUD operations using the steps on the Go ORM example application page.
The following sections break down the example to demonstrate how to perform common tasks required for Go application development using GORM.
Step 1: Import the ORM package
Import the GORM packages by adding the following import statement in your application's main.go
code.
import (
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/postgres"
)
Step 2: Set up the database connection
Go applications can connect to the YugabyteDB database using the gorm.Open()
function.
conn := fmt.Sprintf("host= %s port = %d user = %s password = %s dbname = %s sslmode=disable", host, port, user, password, dbname)
var err error
db, err = gorm.Open("postgres", conn)
defer db.Close()
if err != nil {
panic(err)
}
Parameter | Description | Default |
---|---|---|
host | Hostname of the YugabyteDB instance | localhost |
port | Listen port for YSQL | 5433 |
user | User connecting to the database | yugabyte |
password | Password for connecting to the database | yugabyte |
dbname | Database name | yugabyte |
Step 3: Create a table
Define a struct which maps to the table schema and use AutoMigrate()
to create the table.
type Employee struct {
Id int64 `gorm:"primary_key"`
Name string `gorm:"size:255"`
Age int64
Language string `gorm:"size:255"`
}
...
// Create table
db.Debug().AutoMigrate(&Employee{})
Read more on designing Database schemas and tables.
Step 4: Read and write data
To write data to YugabyteDB, use the db.Create()
function.
// Insert value
db.Create(&Employee{Id: 1, Name: "John", Age: 35, Language: "Golang-GORM"})
db.Create(&Employee{Id: 2, Name: "Smith", Age: 24, Language: "Golang-GORM"})
To query data from YugabyteDB tables, use the db.Find()
function.
// Display input data
var employees []Employee
db.Find(&employees)
for _, employee := range employees {
fmt.Printf("Employee ID:%d\nName:%s\nAge:%d\nLanguage:%s\n", employee.Id, employee.Name, employee.Age, employee.Language)
fmt.Printf("--------------------------------------------------------------\n")
}
Learn more
- Build Go applications using PG
- YugabyteDB smart drivers for YSQL