Driver Introduction🔥
To decouple the database drivers from the main framework library, starting from version v2.1
, all database drivers need to be introduced manually through community packages.
For database driver installation and introduction, please refer to: https://github.com/gogf/gf/tree/master/contrib/drivers
Introduction
The ORM
functionality of the GoFrame
framework is implemented by the gdb
module, used for ORM
operations of common relational databases.
The gdb
database engine uses a connection pool design at the bottom layer, and connections will automatically close when not in use, so there is no need to explicitly use the Close
method to close the database connection when the connection object is no longer needed.
Note: To improve the security of database operations, it is not recommended to directly concatenate parameters into an SQL
string for execution in ORM
operations. It is recommended to use preprocessing (utilizing ?
placeholders extensively) to pass SQL
parameters. The bottom layer of gdb
is implemented using preprocessing to handle the parameters passed by developers, ensuring the safety of database operations.
Interface Documentation:
https://pkg.go.dev/github.com/gogf/gf/v2/database/gdb
Features
The GoFrame ORM
component has the following notable features:
- Fully automated support for nested transactions.
- Interface-oriented design, easy to use and extend.
- Built-in support for mainstream database types and drivers, and easy to extend.
- Powerful configuration management using the framework's unified configuration component.
- Supports singleton mode to obtain database objects of the same configuration group.
- Supports two operation methods: native SQL method operations and ORM chain operations.
- Supports
OpenTelemetry
observability: trace tracing, logging, and metric reporting. - Automatically recognizes
Map/Struct
to receive query results through theScan
method, automating query result initialization and struct type conversion. - Recognizes empty results by returning
nil
, without the need forsql.ErrNoRows
to identify empty query results. - Fully automated struct property-field mapping, without needing to explicitly define struct tags to maintain property-field mapping relationships.
- Automates field recognition and filtering of given
Map/Struct/Slice
parameter types, greatly enhancing query condition input and result reception. - Perfectly supports
DAO
design at theGoFrame
framework layer, fully automatedModel/DAO
code generation, significantly improving development efficiency. - Supports debugging modes, log output,
DryRun
, customHandler
, automatic type conversion, custom interface conversion, and other advanced features. - Supports query caching, soft delete, automatic time updates, model associations, database cluster configurations (software master-slave mode), and other practical features.
g.DB
vs gdb.New
& gdb.Instance
There are three ways to obtain database operation objects: using the g.DB
method (recommended), using the native gdb.New
method, and using the package's native singleton method gdb.Instance
, with the first being the recommended usage. The differences between these three methods are as follows:
- The
g.DB
object management method obtains a singleton object, integrating the management features of the configuration file and supporting hot updates of configuration files. gdb.New
creates a new database object (not a singleton) based on the given database node configuration and cannot use configuration files.gdb.Instance
is the package's native singleton management method, which needs to be used together with the configuration method to obtain the database singleton object for the corresponding configuration by group name (not required).
There are so many ways to obtain objects because GoFrame
is a modular design framework, and each module can be used independently.
Creating a Database Object with New
db, err := gdb.New(gdb.ConfigNode{
Link: "mysql:root:12345678@tcp(127.0.0.1:3306)/test",
})
Obtaining the Database Object Singleton
// Obtain the database object with default configuration (configuration name "default")
db := g.DB()
// Obtain the database object of the configuration group named "user"
db := g.DB("user")
// Obtain the database object singleton using the native singleton management method
db, err := gdb.Instance()
db, err := gdb.Instance("user")
Documentation
🗃️ ORM - Configuration
3 items
🗃️ ORM - Model 🔥
16 items
📄️ ORM - Method Ops (Native)
Using the GoFrame framework for native SQL ORM method operations. This guide explains how to execute complex SQL operations through method manipulation, including database queries, data insertion, updating, deletion, and batch operations, providing detailed code examples.
🗃️ ORM - Transaction
3 items
🗃️ ORM - Result Handling
3 items
📄️ ORM - Timezone
Handles timezone issues in ORM operations within the GoFrame framework, especially for timezone conversion when using the MySQL database. We explain how to control the timezone processing of time.Time objects submitted to the database by setting the loc parameter, providing relevant code examples and configuration advice to help developers better manage timezone during database operations.
📄️ ORM - Model Generation
GoFrame framework provides a simple ORM data table model auto generation feature, implemented through the gf gen dao/model command. It is suitable for developers to quickly generate database models. For specific usage methods, please refer to the relevant development tools section to optimize development efficiency.
🗃️ ORM - Senior Features
11 items
🗃️ ORM - Interface
2 items
📄️ ORM - Context
How to support custom context variables through ORM in the GoFrame framework to achieve asynchronous IO control, trace, nested transactions, etc. With the Ctx method, developers can easily pass custom context variables to achieve more complex request control and tracing. The article provides specific examples and recommendations for request timeout control and model context operations.
🗃️ ORM - Best Practices
3 items
📄️ ORM - FAQ
Common issues that may be encountered while performing ORM operations with the GoFrame framework and their solutions, including connection errors caused by expired database connection pools, ineffective update and insert operations, inability to find database drivers, problems with query conditions having WHERE 0=1, and encoding issues with storing emojis in MySQL tables. Some configuration recommendations are also provided to optimize the experience.