1 Star 0 Fork 0

南京树安信息技术有限公司/ora

Create your Gitee Account
Explore and code with more than 13.5 million developers,Free private repositories !:)
Sign up
文件
Clone or Download
csvdump.go 3.79 KB
Copy Edit Raw Blame History
Tamás Gulácsi authored 2017-03-03 13:18 +08:00 . replace all remaining ora.v3 to ora.v4
/*
Package main in csvdump represents a cursor->csv dumper
Copyright 2013 Tamás Gulácsi
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package main
import (
"bufio"
"database/sql"
"flag"
"fmt"
"io"
"log"
"os"
"strings"
"time"
"github.com/tgulacsi/go/orahlp"
"gopkg.in/errgo.v1"
"gopkg.in/rana/ora.v4/examples/connect"
)
func getQuery(table, where string, columns []string) string {
if strings.HasPrefix(table, "SELECT ") {
return table
}
cols := "*"
if len(columns) > 0 {
cols = strings.Join(columns, ", ")
}
if where == "" {
return "SELECT " + cols + " FROM " + table
}
return "SELECT " + cols + " FROM " + table + " WHERE " + where
}
func dump(w io.Writer, qry string) error {
db, err := connect.GetConnection("")
if err != nil {
return errgo.Notef(err, "connect to database")
}
defer db.Close()
columns, err := GetColumns(db, qry)
if err != nil {
return errgo.Notef(err, "get column converters", err)
}
log.Printf("columns: %#v", columns)
row := make([]interface{}, len(columns))
rowP := make([]interface{}, len(row))
for i := range row {
rowP[i] = &row[i]
}
rows, err := db.Query(qry)
if err != nil {
return errgo.Newf("error executing %q: %s", qry, err)
}
defer rows.Close()
bw := bufio.NewWriterSize(w, 65536)
defer bw.Flush()
for i, col := range columns {
if i > 0 {
bw.Write([]byte{';'})
}
bw.Write([]byte{'"'})
bw.WriteString(col.Name)
bw.Write([]byte{'"'})
}
bw.Write([]byte{'\n'})
n := 0
for rows.Next() {
if err = rows.Scan(rowP...); err != nil {
return errgo.Notef(err, "scan %d. row", n+1)
}
for i, data := range row {
if i > 0 {
bw.Write([]byte{';'})
}
if data == nil {
continue
}
bw.WriteString(columns[i].String(data))
}
bw.Write([]byte{'\n'})
n++
}
log.Printf("written %d rows.", n)
err = rows.Err()
if err != nil {
return err
}
return nil
}
type ColConverter func(interface{}) string
type Column struct {
Name string
String ColConverter
}
func GetColumns(db *sql.DB, qry string) (cols []Column, err error) {
desc, err := orahlp.DescribeSQLQuery(db, qry)
if err != nil {
return nil, errgo.Newf("error getting description for %q: %s", qry, err)
}
log.Printf("desc: %#v", desc)
var ok bool
cols = make([]Column, len(desc))
for i, col := range desc {
cols[i].Name = col.Name
if cols[i].String, ok = converters[col.Type]; !ok {
cols[i].String = defaultConverter
log.Printf("no converter for type %d (column name: %s)", col.Type, col.Name)
}
}
return cols, nil
}
func defaultConverter(data interface{}) string { return fmt.Sprintf("%v", data) }
var converters = map[int]ColConverter{
1: func(data interface{}) string { //VARCHAR2
return fmt.Sprintf("%q", data.(string))
},
6: func(data interface{}) string { //NUMBER
return fmt.Sprintf("%v", data)
},
96: func(data interface{}) string { //CHAR
return fmt.Sprintf("%q", data.(string))
},
156: func(data interface{}) string { //DATE
return `"` + data.(time.Time).Format(time.RFC3339) + `"`
},
}
func main() {
var (
where string
columns []string
)
flag.Parse()
if flag.NArg() > 1 {
where = flag.Arg(1)
if flag.NArg() > 2 {
columns = flag.Args()[2:]
}
}
qry := getQuery(flag.Arg(0), where, columns)
if err := dump(os.Stdout, qry); err != nil {
log.Printf("error dumping: %s", err)
os.Exit(1)
}
os.Exit(0)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/anshuinfo/ora.git
git@gitee.com:anshuinfo/ora.git
anshuinfo
ora
ora
v4.1.19

Search