Database
FastSchema provides a built-in database package db allows you to interact with a database using a simple and intuitive API.
entdbadapter is a package that implements the db.Client interface and is built on top of the Ent ORM, which provides a powerful and flexible way to interact with databases.
If you want to use a different ORM or database package, you can implement the db.Client interface for your package and use it with FastSchema.
DB Client interface
type Client interface {
Dialect() string
// Exec executes a query that does not return records. For example, in SQL, INSERT or UPDATE.
// It return a sql.Result and an error if any.
Exec(ctx context.Context, query string, args ...any) (sql.Result, error)
// Query executes a query that returns rows, typically a SELECT in SQL.
// It return a slice of *entity.Entity and an error if any.
Query(ctx context.Context, query string, args ...any) ([]*entity.Entity, error)
Rollback() error
Commit() error
Tx(ctx context.Context) (Client, error)
IsTx() bool
// Model return the model from given name.
//
// Support finding model from name or types
// If the input model is a string, it will use the name to find the model
// Others, it will use the types of the input to find the model
//
// entities: The entities that the model will be created from
// entities can be one of the following types:
// - []*entity.Entity: The first entity will be used to create the model
// - [][]byte: The first byte slice will be used to create the model by unmarshalling it
Model(model any) (Model, error)
Close() error
SchemaBuilder() *schema.Builder
Reload(
ctx context.Context,
newSchemaBuilder *schema.Builder,
migration *Migration,
disableForeignKeys bool,
enableMigrations ...bool,
) (Client, error)
DB() *sql.DB
Config() *Config
Hooks() *Hooks
}Configuration
type Config struct {
Driver string
Name string
Host string
Port string
User string
Pass string
Logger logger.Logger
LogQueries bool
MigrationDir string
IgnoreMigration bool
Hooks func() *Hooks
}Driver: The database driver to use. Supported drivers aremysql,pgx, andsqlite.Name: The name of the database.Host: The database host.Port: The database port.User: The database user.Pass: The database password.Logger: The logger to use for logging database queries.LogQueries: Whether to log database queries.MigrationDir: The directory where migration files are stored.IgnoreMigration: Whether to ignore migration files.Hooks: A function that returns db hooks.
IMPORTANT
The MigrationDir is required, so you must provide a valid directory path.
Schema Builder
Schema Builder is an instance of schema.Builder and is an important part of FastSchema.
Its primary responsibility is to parse user-generated schemas (created through the Admin UI) and convert them into database schemas.
Moreover, for convenience, the Schema Builder can generate a database schema from any Go struct.
func NewBuilderFromDir(
dir string,
systemSchemaTypes ...any,
) (*Builder, error)dir: The directory where the schema JSON files are stored.systemSchemaTypes: The system schema types.
Example:
type Blog struct {
Name string `json:"name"`
Description string `json:"description"`
}
type Category struct {
Name string `json:"name"`
Description string `json:"description"`
}
schemaDir := "data/schemas"
builder, err := schema.NewBuilderFromDir(schemaDir, Blog{}, Category{})Database Client
The database client is an instance of db.Client and is used to interact with the database.
There are two methods to create a new database client:
Create Database client directly from the entdbadapter package
To create a new database client, you need to pass the database configuration and the schema builder.
Example:
schemaDir := "data/schemas"
migrationDir := "data/migrations"
builder, err := schema.NewBuilderFromDir(schemaDir, Blog{}, Tag{})
if err != nil {
log.Fatal(err)
}
config := &db.Config{
Driver: "mysql",
Name: "fastschema2",
Host: "localhost",
Port: "3306",
User: "root",
Pass: "123",
MigrationDir: migrationDir,
}
client, err := entdbadapter.NewClient(config, builder)
if err != nil {
log.Fatal(err)
}Create Database client using the fastschema application
When creating a new fastschema application, a database client is automatically created and added to the application.
The database client is accessible through the app.DB() method.
Example:
app, err := fastschema.New(&fs.Config{
SystemSchemas: []any{Tag{}, Blog{}},
DBConfig: &db.Config{
Driver: "mysql",
Name: "fastschema",
Host: "localhost",
Port: "3306",
User: "root",
Pass: "123",
MigrationDir: migrationDir,
},
})
if err != nil {
log.Fatal(err)
}
client := app.DB()DBConfig can be omitted if you have the following environment variables set:
DB_DRIVERDB_NAMEDB_HOSTDB_PORTDB_USERDB_PASSDB_LOGGING