/
build_show.go
70 lines (57 loc) · 1.98 KB
/
build_show.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package mysqlfe
/*
import (
"database/sql/driver"
"fmt"
"strings"
u "github.com/araddon/gou"
"github.com/araddon/qlbridge/datasource/membtree"
"github.com/araddon/qlbridge/exec"
"github.com/araddon/qlbridge/plan"
"github.com/araddon/qlbridge/rel"
"github.com/araddon/qlbridge/value"
)
var (
_ = u.EMPTY
)
// Many of the ShowMethods are MySql dialect specific so will be replaced here
func (m *MySqlJob) VisitShow(sp *plan.Show) (plan.Task, plan.WalkStatus, error) {
stmt := sp.Stmt
//u.Debugf("mysql.VisitShow create?%v identity=%q raw=%s", stmt.Create, stmt.Identity, stmt.Raw)
//raw := strings.ToLower(stmt.Raw)
switch {
case stmt.Create && strings.ToLower(stmt.CreateWhat) == "table":
// SHOW CREATE TABLE
// _, tableName, _ := expr.LeftRight(stmt.Identity)
// tableLower := strings.ToLower(tableName)
tbl, _ := m.Ctx.Schema.Table(stmt.Identity)
if tbl == nil {
u.Warnf("no table? %q", stmt.Identity)
return nil, rel.VisitError, fmt.Errorf("No table found for %q", stmt.Identity)
}
// Get the create table statement
createStmt, err := TableCreate(tbl)
if err != nil {
return nil, rel.VisitError, err
}
rows := make([][]driver.Value, 1)
rows[0] = []driver.Value{tbl.Name, createStmt}
source := membtree.NewStaticDataSource("tables", 0, rows, []string{"Table", "Create Table"})
proj := rel.NewProjection()
proj.AddColumnShort("Table", value.StringType)
proj.AddColumnShort("Create Table", value.StringType)
m.Ctx.Projection = plan.NewProjectionStatic(proj)
// tasks := make(exec.Tasks, 0)
// sourceTask := exec.NewSource(m.Ctx, nil, source)
// tasks.Add(sourceTask)
// return exec.NewSequential(m.Ctx, "show-tables", tasks), rel.VisitContinue, nil
u.Debugf("%p has sqlJob? %+v", m, m)
tasks := m.TaskMaker.Sequential("show-create-table")
sourcePlan := plan.NewSourceStaticPlan(m.Ctx)
sourceTask := exec.NewSource(sourcePlan, source)
tasks.Add(sourceTask)
return tasks, rel.VisitContinue, nil
}
return m.SqlJob.VisitShow(sp)
}
*/