sqlx возвращает пустую структуру, даже если она существует
Вот мой код:
package main
import (
"fmt"
"github.com/jmoiron/sqlx"
_ "github.com/lib/pq"
"log"
"time"
)
type Commune struct {
Id int `db:"id"`
Created time.Time `db:"created"`
Modified time.Time `db:"modified"`
Name string `db:"name"`
}
func main() {
var err error
db, err = sqlx.Connect("postgres", "user=toto
dbname=tata password=titi sslmode=disable")
commune := []Commune{}
db.Select(&commune, `SELECT * FROM "Geo_commune" WHERE id=1 ORDER BY name ASC`)
rows, err2 := db.Query(`SELECT * FROM "Geo_commune" WHERE id=1 ORDER BY name ASC`)
fmt.Println(commune)
fmt.Println(rows)
if err != nil {
log.Fatalln(err)
}
if err2 != nil {
log.Fatalln(err2)
}
}
Вот данные в базе данных:
изменить: имя_таблицы:
и я даже пробовал с:
db.Select(&commune, `SELECT * FROM "Geo_commune" WHERE id=1 ORDER BY name ASC`)
но возврат всегда пуст, и я уверен, что данные существуют, и у меня нет ошибки подключения.
Без "Geo_commune"
строки, err2: = db.Query (SELECT * FROM Geo_commune WHERE id=1 ORDER BY name ASC
) у меня есть:
2019/01/28 22:17:16 pq: отношение "geo_commune" не существует
С уважением
редактировать мои новые тесты:
package main
import (
"fmt"
"github.com/jmoiron/sqlx"
"log"
"time"
_ "github.com/lib/pq"
)
type Commune struct {
Id int `db:"id"`
Created time.Time `db:"created"`
Modified time.Time `db:"modified"`
Name string `db:"name"`
}
var db *sqlx.DB
func main() {
var err error
db, err = sqlx.Connect("postgres", "user=toto dbname=titi password=tata sslmode=disable")
commune := []Commune{}
if err != nil {
log.Fatalln(err)
}
db.Select(&commune, `SELECT * FROM "Geo_commune" WHERE id=1 ORDER BY name ASC`)
rows, err2 := db.Query(`SELECT * FROM "Geo_commune" WHERE id=1 ORDER BY name ASC`)
if err != nil {
log.Fatalln(err)
}
if err2 != nil {
log.Fatalln(err2)
}
db.Select(&commune, `SELECT * FROM public.Geo_commune WHERE id=1 ORDER BY name ASC`)
rows, err2 = db.Query(`SELECT * FROM public.Geo_commune WHERE id=1 ORDER BY name ASC`)
fmt.Println(commune)
fmt.Println(rows)
if err != nil {
log.Fatalln(err)
}
if err2 != nil {
log.Fatalln(err2)
}
}
дает мне:
[]
<nil>
2019/01/29 09:50:06 pq: relation "public.geo_commune" does not exist
1 ответ
Я запутался с твоим описанием. это бросило pq: relation "geo_commune" does not exist
? если это так, ваш источник данных неверен. если это не так, попробуйте select * from public.Geo_commune