2022-08-15 12:35:05 +02:00
|
|
|
package bun
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-05-12 14:33:40 +02:00
|
|
|
"database/sql"
|
2022-08-15 12:35:05 +02:00
|
|
|
|
|
|
|
"github.com/uptrace/bun/schema"
|
|
|
|
)
|
|
|
|
|
|
|
|
type RawQuery struct {
|
|
|
|
baseQuery
|
|
|
|
|
|
|
|
query string
|
|
|
|
args []interface{}
|
|
|
|
}
|
|
|
|
|
2022-09-28 19:30:40 +02:00
|
|
|
// Deprecated: Use NewRaw instead. When add it to IDB, it conflicts with the sql.Conn#Raw
|
2022-08-15 12:35:05 +02:00
|
|
|
func (db *DB) Raw(query string, args ...interface{}) *RawQuery {
|
|
|
|
return &RawQuery{
|
|
|
|
baseQuery: baseQuery{
|
|
|
|
db: db,
|
|
|
|
conn: db.DB,
|
|
|
|
},
|
|
|
|
query: query,
|
|
|
|
args: args,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-28 19:30:40 +02:00
|
|
|
func NewRawQuery(db *DB, query string, args ...interface{}) *RawQuery {
|
|
|
|
return &RawQuery{
|
|
|
|
baseQuery: baseQuery{
|
|
|
|
db: db,
|
|
|
|
conn: db.DB,
|
|
|
|
},
|
|
|
|
query: query,
|
|
|
|
args: args,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *RawQuery) Conn(db IConn) *RawQuery {
|
|
|
|
q.setConn(db)
|
|
|
|
return q
|
|
|
|
}
|
|
|
|
|
2023-01-22 12:26:47 +01:00
|
|
|
func (q *RawQuery) Err(err error) *RawQuery {
|
|
|
|
q.setErr(err)
|
|
|
|
return q
|
|
|
|
}
|
|
|
|
|
2023-05-12 14:33:40 +02:00
|
|
|
func (q *RawQuery) Exec(ctx context.Context, dest ...interface{}) (sql.Result, error) {
|
|
|
|
return q.scanOrExec(ctx, dest, len(dest) > 0)
|
|
|
|
}
|
|
|
|
|
2022-08-15 12:35:05 +02:00
|
|
|
func (q *RawQuery) Scan(ctx context.Context, dest ...interface{}) error {
|
2023-05-12 14:33:40 +02:00
|
|
|
_, err := q.scanOrExec(ctx, dest, true)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *RawQuery) scanOrExec(
|
|
|
|
ctx context.Context, dest []interface{}, hasDest bool,
|
|
|
|
) (sql.Result, error) {
|
2022-08-15 12:35:05 +02:00
|
|
|
if q.err != nil {
|
2023-05-12 14:33:40 +02:00
|
|
|
return nil, q.err
|
2022-08-15 12:35:05 +02:00
|
|
|
}
|
|
|
|
|
2023-05-12 14:33:40 +02:00
|
|
|
var model Model
|
|
|
|
var err error
|
|
|
|
|
|
|
|
if hasDest {
|
|
|
|
model, err = q.getModel(dest)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2022-08-15 12:35:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
query := q.db.format(q.query, q.args)
|
2023-05-12 14:33:40 +02:00
|
|
|
var res sql.Result
|
|
|
|
|
|
|
|
if hasDest {
|
|
|
|
res, err = q.scan(ctx, q, query, model, hasDest)
|
|
|
|
} else {
|
|
|
|
res, err = q.exec(ctx, q, query)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return res, nil
|
2022-08-15 12:35:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (q *RawQuery) AppendQuery(fmter schema.Formatter, b []byte) ([]byte, error) {
|
|
|
|
return fmter.AppendQuery(b, q.query, q.args...), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *RawQuery) Operation() string {
|
|
|
|
return "SELECT"
|
|
|
|
}
|