Sha256: 0214f165377e5e7692cbd2d5a195c1fa79aa5dee13536cd0c50a775b1d45f301

Contents?: true

Size: 1.49 KB

Versions: 20

Compression:

Stored size: 1.49 KB

Contents

package main

import (
	"bufio"
	"encoding/json"
	"flag"
	"fmt"
	"io"
	"os"

	"github.com/xwb1989/sqlparser"
)

type query struct {
	Table   string   `json:"table"`
	Columns []string `json:"columns"`
}

func init() {
	flag.Usage = func() {
		fmt.Fprintf(os.Stderr, "Takes queries from stdin and converst them to json.\n")
	}
}

func main() {
	parseQueries(os.Stdin)
}

func parseQueries(r io.Reader) {
	scanner := bufio.NewScanner(r)

	enc := json.NewEncoder(os.Stdout)

	for scanner.Scan() {
		sql := scanner.Text()
		stmt, err := sqlparser.Parse(sql)

		if err != nil {
			fmt.Println("Unable to parse line", sql)
			fmt.Fprintln(os.Stderr, err)
		}

		switch q := stmt.(type) {
		case *sqlparser.Select:
			parsed := parse(q)
			enc.Encode(parsed)
		case *sqlparser.Insert:
			enc.Encode(parseTable(q))
		default:
			fmt.Fprintln(os.Stderr, "Query not supported: ", sqlparser.String(stmt))
		}
	}

	if err := scanner.Err(); err != nil {
		fmt.Fprintln(os.Stderr, "reading standard input:", err)
	}
}

func parseTable(q *sqlparser.Insert) string {
	return sqlparser.String(q.Table)
}

func parse(q *sqlparser.Select) query {
	// fixme: assume simple table from
	//tables := sqlparser.String(q.From[0])
	table := sqlparser.String(q.From)
	columns := []string{}
	sqlparser.Walk(func(node sqlparser.SQLNode) (bool, error) {
		switch node.(type) {
		case *sqlparser.ColName:
			c := sqlparser.String(node)
			columns = append(columns, c)
		}

		return true, nil
	}, q.Where)

	return query{Table: table, Columns: columns}
}

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
shiba-0.9.4 cmd/parse.go
shiba-0.9.3 cmd/parse.go
shiba-0.9.2 cmd/parse.go
shiba-0.9.1 cmd/parse.go
shiba-0.9.0 cmd/parse.go
shiba-0.8.1 cmd/parse.go
shiba-0.6.4 cmd/parse.go
shiba-0.6.3 cmd/parse.go
shiba-0.6.2 cmd/parse.go
shiba-0.6.1 cmd/parse.go
shiba-0.6.0 cmd/parse.go
shiba-0.5.0 cmd/parse.go
shiba-0.4.0 cmd/parse.go
shiba-0.3.0 cmd/parse.go
shiba-0.2.3 cmd/parse.go
shiba-0.2.2 cmd/parse.go
shiba-0.2.0 cmd/parse.go
shiba-0.1.2 cmd/parse.go
shiba-0.1.1 cmd/parse.go
shiba-0.1.0 cmd/parse.go