Есть ли способ увидеть результат применения аргументов к запросу в sqlite? - PullRequest
0 голосов
/ 05 июля 2019

Я использую sqlite3 в Go и для целей отладки хотел бы видеть результат применения аргументов к запросу с заменами, т. Е. С? заменено фактическим аргументом. Возможно ли это?

В настоящее время у меня есть код, подобный следующему, и напечатанный запрос FTS5 выглядит хорошо:

SELECT ownerid FROM __ftsindex WHERE ownertable=? AND 
__ftsindex MATCH ? AND ( __ftsindex MATCH ? ) LIMIT ?;

Он не возвращает ошибку, но также не находит то, что должен найти, и я не знаю, как дальше отладить это:

for i := range trails {
    if i == 0 {
        s += `( __ftsindex MATCH ?`
    } else {
        s += ` OR __ftsindex MATCH ?`
    }
}
s += " )"
query = fmt.Sprintf(`SELECT ownerid FROM __ftsindex WHERE ownertable=? AND __ftsindex MATCH ? AND %s LIMIT ?;`, s)
fmt.Println(query)
args := make([]interface{}, len(trails)+3)
args[0] = cat.Table()
args[1] = searchTerm
for i := range trails {
    args[i+2] = trails[i]
}
args[len(args)-1] = limit
rows, err := model.DB.Base().Query(query, args...)

1 Ответ

1 голос
/ 05 июля 2019

Если вы не получаете ожидаемых результатов SQL-запроса, в ваших входных аргументах могут быть ошибочные байты.

Я бы предложил регистрировать каждый отдельный аргумент, используя %+q:

for i, arg := range sqlArgs {
    if _, ok := arg.(string); ok {
        log.Printf("arg %d) %+q\n", i+1, arg) // catches any 'invisible' bytes or visually similar characters
    } else {
        log.Printf("arg %d) `%v`\n", i+1, arg)
    }
}

Например: https://play.golang.org/p/mDsnIjMAVwP

PS Посмотрите этот отличный пост в блоге о том, как визуализировать скрытые кодировки строк и байтов-фрагментов.

...