Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luismarchio03/golang_migration_system
A database migration system in Go (Golang) that centralizes functions for managing database migrations across different database types, including MySQL, PostgreSQL, and FirebirdSQL. The project includes automated testing and Docker integration to facilitate migration management and execution in development and production environments.
https://github.com/luismarchio03/golang_migration_system
ci-cd database functional-programming github-actions go golang lib library migration nosql sql
Last synced: 6 days ago
JSON representation
A database migration system in Go (Golang) that centralizes functions for managing database migrations across different database types, including MySQL, PostgreSQL, and FirebirdSQL. The project includes automated testing and Docker integration to facilitate migration management and execution in development and production environments.
- Host: GitHub
- URL: https://github.com/luismarchio03/golang_migration_system
- Owner: LuisMarchio03
- Created: 2024-04-19T20:36:55.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-04-30T19:15:43.000Z (9 months ago)
- Last Synced: 2024-11-21T12:47:54.962Z (2 months ago)
- Topics: ci-cd, database, functional-programming, github-actions, go, golang, lib, library, migration, nosql, sql
- Language: Go
- Homepage:
- Size: 1.57 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Golang Migration System
## Description
A database migration system in Go (Golang) that centralizes functions for managing database migrations across different database types, including MySQL, PostgreSQL, and FirebirdSQL. The project includes automated testing and Docker integration to facilitate migration management and execution in development and production environments.
## Installation
To install the library, you can use the go get command:
```bash
go get github.com/LuisMarchio03/golang_migration_system
```## Usage
The library offers simple functionalities to configure and execute database migrations. Here's a basic example of how you can use it:
```bash
package mainimport (
"fmt"
"github.com/LuisMarchio03/golang_migration_system"
)func main() {
// Database configuration
cfg := golang_migration_system.Cfg{
User: "root",
Passwd: "password",
Net: "tcp",
Addr: "localhost:3306",
DBName: "my_database",
}// Configure the database
db, err := golang_migration_system.ConfigDB("MySql", cfg)
if err != nil {
fmt.Println("Error configuring the database:", err)
return
}// Define the table schema
schema := golang_migration_system.Schema{
TableName: "users",
Fields: map[string]string{
"id": "INT NOT NULL AUTO_INCREMENT PRIMARY KEY",
"username": "VARCHAR(50) NOT NULL",
"email": "VARCHAR(100) NOT NULL",
"created_at": "TIMESTAMP DEFAULT CURRENT_TIMESTAMP",
"updated_at": "TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP",
},
}// Generate the migration
migrationFileName, err := golang_migration_system.GenerateMigration(schema)
if err != nil {
fmt.Println("Error generating migration:", err)
return
}fmt.Println("Migration generated successfully:", migrationFileName)
// Execute migrations
err = golang_migration_system.RunMigrations(db)
if err != nil {
fmt.Println("Error executing migrations:", err)
return
}fmt.Println("Migrations completed successfully.")
}
```## Contributions
Contributions are welcome! If you find an issue or have an idea to improve the library, feel free to open an issue or submit a pull request.
## License
Just replace the `[MIT License](LICENSE)` link with the appropriate link to your license file or the license text itself.