Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qustavo/dotsql
A Golang library for using SQL.
https://github.com/qustavo/dotsql
go golang-library sql
Last synced: 1 day ago
JSON representation
A Golang library for using SQL.
- Host: GitHub
- URL: https://github.com/qustavo/dotsql
- Owner: qustavo
- License: gpl-2.0
- Created: 2014-11-20T12:14:39.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2023-11-24T08:19:45.000Z (about 1 year ago)
- Last Synced: 2025-01-19T17:48:38.386Z (1 day ago)
- Topics: go, golang-library, sql
- Language: Go
- Size: 67.4 KB
- Stars: 743
- Watchers: 26
- Forks: 53
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go-extra - dotsql - 11-20T12:14:39Z|2022-06-07T07:36:02Z| (Generators / SQL Query Builders)
README
dotsql
[![GoDoc](https://godoc.org/github.com/qustavo/dotsql?status.svg)](https://godoc.org/github.com/qustavo/dotsql)
[![Build Status](https://travis-ci.org/qustavo/dotsql.svg)](https://travis-ci.org/qustavo/dotsql)
[![Test coverage](https://gocover.io/_badge/github.com/qustavo/dotsql)](https://gocover.io/github.com/qustavo/dotsql)
[![Go Report Card](https://goreportcard.com/badge/github.com/qustavo/dotsql)](https://goreportcard.com/report/github.com/qustavo/dotsql)
======A Golang library for using SQL.
It is not an ORM, it is not a query builder. Dotsql is a library that helps you
keep sql files in one place and use it with ease._Dotsql is heavily inspired by_ [yesql](https://github.com/krisajenkins/yesql).
Installation
--
```bash
$ go get github.com/qustavo/dotsql
```Usage
--First of all, you need to define queries inside your sql file:
```sql
-- name: create-users-table
CREATE TABLE users (
id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
name VARCHAR(255),
email VARCHAR(255)
);-- name: create-user
INSERT INTO users (name, email) VALUES(?, ?)-- name: find-users-by-email
SELECT id,name,email FROM users WHERE email = ?-- name: find-one-user-by-email
SELECT id,name,email FROM users WHERE email = ? LIMIT 1--name: drop-users-table
DROP TABLE users
```Notice that every query has a name tag (`--name:`),
this is needed to be able to uniquely identify each query
inside dotsql.With your sql file prepared, you can load it up and start utilizing your queries:
```go
// Get a database handle
db, err := sql.Open("sqlite3", ":memory:")// Loads queries from file
dot, err := dotsql.LoadFromFile("queries.sql")// Run queries
res, err := dot.Exec(db, "create-users-table")
res, err := dot.Exec(db, "create-user", "User Name", "[email protected]")
rows, err := dot.Query(db, "find-users-by-email", "[email protected]")
row, err := dot.QueryRow(db, "find-one-user-by-email", "[email protected]")stmt, err := dot.Prepare(db, "drop-users-table")
result, err := stmt.Exec()
```You can also merge multiple dotsql instances created from different sql file inputs:
```go
dot1, err := dotsql.LoadFromFile("queries1.sql")
dot2, err := dotsql.LoadFromFile("queries2.sql")
dot := dotsql.Merge(dot1, dot2)
```Text Interpolation
--
[text/template](https://pkg.go.dev/text/template)-style text interpolation is supported.To use, call `.WithData(any)` on your dotsql instance to
create a new instance which passes those values into the templating library.```sql
-- name: count-users
SELECT count(*) FROM users {{if .exclude_deleted}}WHERE deleted IS NULL{{end}}
``````go
dotsql.WithData(map[string]any{"exclude_deleted": true}).Query(db, "count-users")
```Embeding
--
To avoid distributing `sql` files alongside the binary file, you will need to use tools like
[gotic](https://github.com/qustavo/gotic) to embed / pack everything into one file.SQLX
--
For [sqlx](https://github.com/jmoiron/sqlx) support check [dotsqlx](https://github.com/swithek/dotsqlx)