Skip to content

ystyle/sqlmanager

Repository files navigation

Go Report Card License GoDoc

sqlmanager

a library for manager sql with markdown or constant. and you can custom sql store plugin.

Not A Go ORM Library

feature

  • 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

usage

install

go get github.com/ystyle/sqlmanager/v2

create a markdown in

markdown content in sql/test.md

    ### GetStudentByID
    >get student by id, required id
    ```sql
    select * from student where id = {{.}}
    ```

Use Available plugins

  1. 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 
    }
  2. 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

  3. 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)
  4. 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 call sm.load(), it mean you should run sm.load() after changes

     create 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)
    }

custom puglin

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
}

About

manager sql with markdown

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages