Domyślam się, że pq.Array
daje tablicę PostgreSQL w postaci ciągu, więc otrzymujesz coś takiego:
unnest('{a,b,c,d,e}')
a PostgreSQL nie jest pewien, jak powinien interpretować ten ciąg, stąd skarga dotycząca unnest(unknown)
. Powinieneś być w stanie dodać wyraźny typ rzutowania, aby wyjaśnić sytuację:
unnest($1::text[]) -- PostgreSQL-specific casting syntax
unnest(cast($1 as text[])) -- Standard casting syntax
Otrzymasz coś takiego:
rows, err := db.Query("select colname from (SELECT date, unnest($1::text[]) AS colname, unnest($1) AS thing from test1 where date='123') as tester where thing=1;", pq.Array(arr1))