2017-08-27 14:09:31 +00:00
|
|
|
// Copyright 2017 The Xorm Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package xorm
|
|
|
|
|
2021-08-27 06:50:08 +00:00
|
|
|
func (session *Session) queryBytes(sqlStr string, args ...interface{}) ([]map[string][]byte, error) {
|
|
|
|
rows, err := session.queryRows(sqlStr, args...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
return rows2maps(rows)
|
|
|
|
}
|
2017-08-27 14:09:31 +00:00
|
|
|
|
2017-11-20 08:14:27 +00:00
|
|
|
// Query runs a raw sql and return records as []map[string][]byte
|
2019-06-06 02:55:52 +00:00
|
|
|
func (session *Session) Query(sqlOrArgs ...interface{}) ([]map[string][]byte, error) {
|
2017-11-20 08:14:27 +00:00
|
|
|
if session.isAutoClose {
|
|
|
|
defer session.Close()
|
|
|
|
}
|
|
|
|
|
2020-02-28 12:29:08 +00:00
|
|
|
sqlStr, args, err := session.statement.GenQuerySQL(sqlOrArgs...)
|
2017-11-20 08:14:27 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2017-11-15 03:34:59 +00:00
|
|
|
}
|
|
|
|
|
2017-08-27 14:09:31 +00:00
|
|
|
return session.queryBytes(sqlStr, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryString runs a raw sql and return records as []map[string]string
|
2019-06-06 02:55:52 +00:00
|
|
|
func (session *Session) QueryString(sqlOrArgs ...interface{}) ([]map[string]string, error) {
|
2017-08-27 14:09:31 +00:00
|
|
|
if session.isAutoClose {
|
|
|
|
defer session.Close()
|
|
|
|
}
|
|
|
|
|
2020-02-28 12:29:08 +00:00
|
|
|
sqlStr, args, err := session.statement.GenQuerySQL(sqlOrArgs...)
|
2017-11-20 08:14:27 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2017-08-27 14:09:31 +00:00
|
|
|
rows, err := session.queryRows(sqlStr, args...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
2021-08-27 06:50:08 +00:00
|
|
|
return session.engine.ScanStringMaps(rows)
|
2017-08-27 14:09:31 +00:00
|
|
|
}
|
|
|
|
|
2018-10-15 05:03:43 +00:00
|
|
|
// QuerySliceString runs a raw sql and return records as [][]string
|
2019-06-06 02:55:52 +00:00
|
|
|
func (session *Session) QuerySliceString(sqlOrArgs ...interface{}) ([][]string, error) {
|
2018-10-15 05:03:43 +00:00
|
|
|
if session.isAutoClose {
|
|
|
|
defer session.Close()
|
|
|
|
}
|
|
|
|
|
2020-02-28 12:29:08 +00:00
|
|
|
sqlStr, args, err := session.statement.GenQuerySQL(sqlOrArgs...)
|
2018-10-15 05:03:43 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
rows, err := session.queryRows(sqlStr, args...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
2021-08-27 06:50:08 +00:00
|
|
|
return session.engine.ScanStringSlices(rows)
|
2017-08-27 14:09:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryInterface runs a raw sql and return records as []map[string]interface{}
|
2019-06-06 02:55:52 +00:00
|
|
|
func (session *Session) QueryInterface(sqlOrArgs ...interface{}) ([]map[string]interface{}, error) {
|
2017-08-27 14:09:31 +00:00
|
|
|
if session.isAutoClose {
|
|
|
|
defer session.Close()
|
|
|
|
}
|
|
|
|
|
2020-02-28 12:29:08 +00:00
|
|
|
sqlStr, args, err := session.statement.GenQuerySQL(sqlOrArgs...)
|
2017-11-20 08:14:27 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2017-08-27 14:09:31 +00:00
|
|
|
rows, err := session.queryRows(sqlStr, args...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
2021-08-27 06:50:08 +00:00
|
|
|
return session.engine.ScanInterfaceMaps(rows)
|
2017-08-27 14:09:31 +00:00
|
|
|
}
|