Sqlfmt formats SQL queries or SQL statements in .go files into a consistent format.
This is a fork of https://github.com/kanmu/go-sqlfmt which seems to abandoned. Some of its open pull requests were applied too. The complete code was simplified, cleaned up and restructured.
import "github.com/noneymous/go-sqlfmt/sqlfmt"
sql := `
select xxx ,xxx ,xxx
, case
when xxx is null then xxx
else true
end as xxx
from xxx as xxx join xxx on xxx = xxx join xxx as xxx on xxx = xxx
left outer join xxx as xxx
on xxx = xxx
where xxx in ( select xxx from ( select xxx from xxx ) as xxx where xxx = xxx )
order by xxx
`
sqlFormatted, errFormat := sqlfmt.Format(sql, &sqlfmt.Options{})
if errFormat != nil {
return
}go get github.com/noneymous/go-sqlfmt/cmd/sqlfmtUnformatted SQL in a .go file
package main
import (
"database/sql"
)
func sendSQL() int {
var id int
var db *sql.DB
db.QueryRow(`
select xxx ,xxx ,xxx
, case
when xxx is null then xxx
else true
end as xxx
from xxx as xxx join xxx on xxx = xxx join xxx as xxx on xxx = xxx
left outer join xxx as xxx
on xxx = xxx
where xxx in ( select xxx from ( select xxx from xxx ) as xxx where xxx = xxx )
and xxx in ($2, $3) order by xxx`).Scan(&id)
return id
}Provide flags and input files or directory
$ sqlfmt -w input_file.go -l
Do not print reformatted sources to standard output.
If a file's formatting is different from src, print its name
to standard output.
-d
Do not print reformatted sources to standard output.
If a file's formatting is different than src, print diffs
to standard output.
-w
Do not print reformatted sources to standard output.
If a file's formatting is different from src, overwrite it
with gofmt style.
-distance
Write the distance from the edge to the begin of SQL statements
The sqlfmt is currently only able to format SQL statements in QueryRow, Query, Exec functions from the "database/sql" package.
The following SQL statements will be formatted
func sendSQL() int {
var id int
var db *sql.DB
db.QueryRow(`select xxx from xxx`).Scan(&id)
return id
}to
func sendSQL() int {
var id int
var db *sql.DB
db.QueryRow(`
SELECT
xxx
FROM xxx`).Scan(&id)
return id
}Thank you for thinking of contributing to the sqlfmt! Pull Requests are welcome!
MIT