Files
go-gin-api/internal/api/controller/tool_handler/func_tables.go
新亮 8ed27cdce1 feature(1.2.8): 使用 embed 打包静态资源
- go version 升级为 1.16
- 使用 embed 特性,将静态资源打包进二进制文件
- 优化代码
2021-11-20 15:01:50 +08:00

77 lines
1.9 KiB
Go

package tool_handler
import (
"fmt"
"net/http"
"github.com/xinliangnote/go-gin-api/internal/code"
"github.com/xinliangnote/go-gin-api/internal/pkg/core"
"github.com/xinliangnote/go-gin-api/pkg/errno"
)
type tablesRequest struct {
DbName string `form:"db_name"` // 数据库名称
}
type tablesResponse struct {
List []tableData `json:"list"` // 数据表列表
}
type tableData struct {
Name string `json:"table_name"` // 数据表名称
Comment string `json:"table_comment"` // 数据表备注
}
// Tables 查询 Table
// @Summary 查询 Table
// @Description 查询 Table
// @Tags API.tool
// @Accept multipart/form-data
// @Produce json
// @Param db_name formData string true "数据库名称"
// @Success 200 {object} tablesResponse
// @Failure 400 {object} code.Failure
// @Router /api/tool/data/tables [post]
func (h *handler) Tables() core.HandlerFunc {
return func(c core.Context) {
req := new(tablesRequest)
res := new(tablesResponse)
if err := c.ShouldBindForm(req); err != nil {
c.AbortWithError(errno.NewError(
http.StatusBadRequest,
code.ParamBindError,
code.Text(code.ParamBindError)).WithErr(err),
)
return
}
sqlTables := fmt.Sprintf("SELECT `table_name`,`table_comment` FROM `information_schema`.`tables` WHERE `table_schema`= '%s'", req.DbName)
// TODO 后期支持查询多个数据库
rows, err := h.db.GetDbR().Raw(sqlTables).Rows()
if err != nil {
c.AbortWithError(errno.NewError(
http.StatusBadRequest,
code.MySQLExecError,
code.Text(code.MySQLExecError)).WithErr(err),
)
return
}
defer rows.Close()
for rows.Next() {
var info tableData
err = rows.Scan(&info.Name, &info.Comment)
if err != nil {
fmt.Printf("execute query tables action error,had ignored, detail is [%v]\n", err.Error())
continue
}
res.List = append(res.List, info)
}
c.Payload(res)
}
}