
前提条件
- 安装
PostgreSql
,创建好数据库(GORM 自动迁移表结构)
- 安装
GoLand
和 Go SDK
- 获取 GORM:
go get -u gorm.io/gorm
- 获取 Postgres 驱动:
go get -u gorm.io/driver/postgres
使用说明
- 复制本代码,打开
GoLand
- 按 Ctrl + Shift + Alt + Insert 创建草稿文件
- 将代码粘贴到草稿文件中,修改数据库连接地址,按 Ctrl + Shift + F10 运行代码查看效果
package main
import (
"database/sql"
"encoding/json"
"errors"
"fmt"
"gorm.io/driver/postgres"
"gorm.io/gorm"
"gorm.io/gorm/logger"
"gorm.io/gorm/schema"
"log"
"os"
"strconv"
"time"
)
type TSysParam struct {
ID string `gorm:"type:varchar(32);not null;primaryKey;<-:create;comment:流水号参数唯一 ID"`
DataTableName string `gorm:"type:varchar(128);<-;comment:数据库表名,如“t_sys_user”"`
DataTableDescription string `gorm:"type:varchar(255);<-;comment:数据库表名(中文)说明信息"`
SerialValue int `gorm:"size:32;<-;comment:流水号当前最大值"`
SerialLength int `gorm:"size:32;<-;comment:流水号长度,不足前缀以“0”补齐"`
Remark string `gorm:"type:varchar(1024);<-;comment:备注信息"`
Enabled bool `gorm:"<-;default:true;comment:是否可用"`
CreateTime *time.Time `gorm:"type:timestamptz;<-:create;autoCreateTime:milli;comment:创建时间"`
CreateBy string `gorm:"type:varchar(32);<-:create;comment:创建人 ID,t_sys_user.id"`
LastUpdateTime *time.Time `gorm:"type:timestamptz;<-;comment:最后修改时间"`
LastUpdateBy string `gorm:"type:varchar(32);<-;comment:最后修改人 ID,t_sys_user.id"`
}
func main() {
initDbConn()
createExample()
readExample()
updateExample()
deleteExample()
printStats()
}
var GormDB *gorm.DB
var SqlDB *sql.DB
var err error
func initDbConn() {
GormDB, err = gorm.Open(postgres.New(postgres.Config{
DSN: "host=192.168.1.1 port=5432 user=test password=test dbname=db_test sslmode=disable TimeZone=Asia/Shanghai",
PreferSimpleProtocol: true,
}), &gorm.Config{
Logger: getLogger(),
NamingStrategy: schema.NamingStrategy{
SingularTable: true,
},
CreateBatchSize: 1000,
})
if err != nil {
panic("数据库连接失败!")
}
SqlDB, err = GormDB.DB()
if err != nil {
panic("数据库连接池获取失败!")
}
SqlDB.SetMaxIdleConns(10)
SqlDB.SetMaxOpenConns(1e3)
SqlDB.SetConnMaxLifetime(time.Hour)
printStats()
}
func nowTime() *time.Time {
now := time.Now()
return &now
}
func createExample() {
sysParam := TSysParam{
ID: "test_001",
DataTableName: "test_table",
DataTableDescription: "测试表",
SerialValue: 0,
SerialLength: 10,
Enabled: true,
CreateBy: "00000",
CreateTime: nowTime(),
}
result := GormDB.Create(&sysParam)
printData(&sysParam, result, "Create")
sysParam = TSysParam{
ID: "test_002",
DataTableName: "test_table_002",
DataTableDescription: "测试表",
SerialValue: 0,
SerialLength: 10,
Enabled: true,
CreateBy: "00000",
}
result = GormDB.
Select("ID", "DataTableName", "DataTableDescription", "SerialValue", "SerialLength").
Create(&sysParam)
printData(&sysParam, result, "Create")
dataSize := 3
sysParams := make([]TSysParam, dataSize)
for i := 0; i < dataSize; i++ {
index := strconv.Itoa(i)
sysParams[i] = TSysParam{
ID: "test_list_" + index,
DataTableName: "test_table_" + index,
DataTableDescription: "测试表_" + index,
SerialValue: 0,
SerialLength: 10,
Enabled: true,
CreateBy: "00000",
}
}
result = GormDB.Create(&sysParams)
printData(&sysParams, result, "Create", "(batch)")
}
func readExample() {
var sysParam *TSysParam
result := GormDB.First(&sysParam, "00001")
printData(sysParam, result, "First")
sysParam = nil
result = GormDB.Last(&sysParam, "enabled = ?", false)
printData(sysParam, result, "Last")
sysParam = nil
result = GormDB.Take(&sysParam, "create_by = ?", "00000")
printData(sysParam, result, "Take")
sysParam = nil
result = GormDB.Table("t_sys_param").First(&sysParam)
printData(sysParam, result, "Table", "First")
sysParam = nil
sysParams := new([]TSysParam)
result = GormDB.Find(&sysParams, "enabled = ?", true)
printData(&sysParams, result, "Find", "(all)")
sysParams = new([]TSysParam)
result = GormDB.Find(&sysParams, TSysParam{Enabled: true, CreateBy: "00000"})
printData(&sysParams, result, "Find", "(AND)")
sysParams = new([]TSysParam)
result = GormDB.Where("enabled", true).Or("create_by", "00000").Find(&sysParams)
printData(&sysParams, result, "Find", "(OR)")
sysParams = new([]TSysParam)
result = GormDB.Find(&sysParams, "id IN ?", []string{"00001", "00002"})
printData(&sysParams, result, "Find", "(IN)")
sysParams = new([]TSysParam)
result = GormDB.Not("serial_value", 0).Find(&sysParams)
printData(&sysParams, result, "Find", "(NOT)")
sysParams = new([]TSysParam)
allSysParams := new([]TSysParam)
result = GormDB.
Offset(5).Limit(5).
Order("serial_value DESC, id").
Select("data_table_name", "serial_value", "serial_length").
Find(&sysParams)
printData(&sysParams, result, "Find", "(select-order-paging)")
unpageResult := result.Offset(-1).Limit(-1).Find(&allSysParams)
printData(&allSysParams, unpageResult, "Find", "(select-order-paging-all)")
}
func updateExample() {
sysParam := TSysParam{
ID: "test_001",
DataTableName: "test_table_001",
DataTableDescription: "测试表-001",
SerialValue: 1,
SerialLength: 10,
Enabled: true,
CreateTime: nowTime(),
CreateBy: "00001",
LastUpdateTime: nowTime(),
LastUpdateBy: "00000",
}
result := GormDB.Save(&sysParam).
Find(&sysParam)
printData(&sysParam, result, "UPDATE", "Save")
result = GormDB.Model(&sysParam).
Where("enabled", true).
Update("serial_value", sysParam.SerialValue+1).
Find(&sysParam)
printData(&sysParam, result, "UPDATE", "Model", "WhereUpdate")
sysParam = TSysParam{
ID: "test_001",
SerialValue: sysParam.SerialValue + 1,
SerialLength: 10,
Enabled: false,
LastUpdateTime: nowTime(),
LastUpdateBy: "00000",
}
result = GormDB.Model(&sysParam).
Where("enabled", true).
Updates(&sysParam).
Find(&sysParam)
printData(&sysParam, result, "UPDATE", "Model", "Updates")
result = GormDB.Model(&sysParam).
Updates(map[string]interface{}{"serial_value": sysParam.SerialValue + 1, "enabled": false}).
Find(&sysParam)
printData(&sysParam, result, "UPDATE", "Model", "UpdatesMap")
result = GormDB.Model(&sysParam).
Omit("serial_value").
Updates(map[string]interface{}{"serial_value": sysParam.SerialValue + 1, "enabled": true}).
Find(&sysParam)
printData(&sysParam, result, "UPDATE", "Model", "UpdatesOmit")
}
func deleteExample() {
sysParam := TSysParam{
ID: "test_002",
}
result := GormDB.Delete(&sysParam)
sysParam = TSysParam{}
result.Find(&sysParam)
printData(&sysParam, result, "Delete")
result = GormDB.Where("id LIKE ? AND data_table_name LIKE ?", "test_%", "test_table_%").
Delete(&sysParam).
Find(&sysParam)
printData(&sysParam, result, "DeleteWhere")
}
func getLogger() logger.Interface {
gormLogger := logger.New(
log.New(os.Stdout, "\r\n", log.LstdFlags),
logger.Config{
SlowThreshold: 3 * time.Second,
LogLevel: logger.Info,
Colorful: true,
},
)
return gormLogger
}
func printData(sysParam interface{}, result *gorm.DB, morInfo ...interface{}) {
jsonByte, _ := json.Marshal(&sysParam)
result.Logger.Info(nil, string(jsonByte))
fmt.Println("条数:", result.RowsAffected,
"\t错误信息:[", result.Error,
"]\t是否为无记录错误:", errors.Is(result.Error, gorm.ErrRecordNotFound))
if len(morInfo) > 0 {
fmt.Println(morInfo)
}
}
func printStats() {
dbStats := SqlDB.Stats()
jsonByte, _ := json.Marshal(dbStats)
fmt.Println(string(jsonByte))
}
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于