a library for manager sql with markdown or constant. and you can custom sql store plugin.
Not A Go ORM Library
- manage sql with markdown
- render sql with sqltemplate(fork from go template)
- generates sql statements with ? placeholders, and arguments list
- support load sql with custom plugin
go get github.com/ystyle/sqlmanager/v2
markdown content in sql/test.md
### GetStudentByID
>get student by id, required id
```sql
select * from student where id = {{.}}
```
-
File Driver: using *.md file
package main import ( "fmt" "github.com/ystyle/sqlmanager" "github.com/ystyle/sqltemplate" ) func main() { sm := sqlmanager.New() sm.Use(sqlmanager.NewMarkdownDriver()) // load sql with custom dir // sm.Use(sqlmanager.NewMarkdownDriverWithDir("./prod-sql")) // register go template func // sm.RegisterFunc(sqltemplate.FuncMap{ // "upper": func(v string) string { // return strings.ToUpper(v) // }, // }) sm.Load() sql, args, err := sm.RenderTPL("test/GetStudentByID", 1) if err != nil { panic(err) } fmt.Println(sql) fmt.Println(args) // select * from student where id = ? // [1] // using gorm // db, err := gorm.Open("databaseurl") // if err != nil { // panic("failed to connect database") // } // db.Raw(sql, args...) // db log: select * from student where id = 1 // using database/sql // db, err := sql.Open("driver-name", "database=test1") // if err != nil { // log.Fatal(err) // } // db.Query(sql, args...) // db log: select * from student where id = 1 }
-
Embed markdown Driver: using go embed.
//go:embed test-sql var Assets embed.FS func main() { sm = sqlmanager.New() sm.Use(sqlmanager.NewMarkdownDriverWithEmbedDir(Assets, "test-sql")) // sm.Use(sqlmanager.NewMarkdownDriverWithEmbed(Assets)) // default dir is sql sm.load() sql,args, _ := sm.RenderTPL("test/GetStudentByID", 1) }
when the sql in
test-sql/admin/report.md/###GetStudentByRoot
the sql id is:admin/report/GetStudentByRoot
-
Dynamic Driver: using variable.
store := sqlmanager.NewDynamicDriver() const GetStudentByID = "select * from student where id = {{.}}" store.RegisterWithDescs("GetStudentByID", "Query Student by ID", GetStudentByID) sm := sqlmanager.New() sm.Use(store) sm.load() sql, args, _ := sm.RenderTPL("GetStudentByID", 1)
-
Database Driver: store in database
you can custom the table name, and delete row should set deleted = 1, deleted_at = now(). you can build a interface to manage your sqls in your product.
Field names: name, deleted, deleted_at, description, sql are required in this table. load sql only on callsm.load()
, it mean you should runsm.load()
after changescreate table sql_manager ( id int unsigned auto_increment primary key, name varchar(255) null, deleted int default 0 not null, deleted_at datetime null, description varchar(255) null, `sql` text null, constraint sql_manager_deleted_name_uindex unique (deleted, name) ); INSERT INTO sql_manager (name, deleted, deleted_at, description, `sql`) VALUES ('GetStudentByID', 0, null, 'get student by id, required id', 'select * from student where id = {{.}}');
import ( "database/sql" _ "github.com/go-sql-driver/mysql" ) func main() { db, _ := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/test") sm = sqlmanager.New() sm.Use(sqlmanager.NewDatabaseDriver(db, "sql_manager")) sm.load() sql, args, _ := sm.RenderTPL("GetStudentByID", 1) }
implement sqlmanager.Driver
type CustomeDriver struct {
}
func NewCustomeDriver() *CustomeDriver {
return &CustomeDriver{}
}
func (mdd *CustomeDriver ) DriverName() string {
return "CustomeDriver"
}
func (mdd *CustomeDriver ) Load() ([]sqlmanager.SqlTemple, error) {
var list []sqlmanager.SqlTemple
// db.table("sql_store").Find(&list)
return list, nil
}