2016-09-12 3 views
0

、私は次のように?を使用しようとしています「WITH」のために動作しません(私は、クエリを生成するGolangでそれを使用しますが、それが依存して行くされていないように思える):PostgreSQL "?"引数プレースホルダは

WITH Tmp(name, enabled) AS (
    VALUES(?, ?),(?, ?) 
) 
UPDATE table_groups 
    SET enabled = (SELECT enabled 
        FROM Tmp 
        WHERE table_groups.name=Tmp.name) 
WHERE table_groups.name IN (SELECT name FROM Tmp) 

取得します:

syntax error at or near "," 

具体的な値で上記の文の代わりに?を使用すると、すべて正常に動作します。 WITH?を使用しているときに問題があります。どうすれば回避できますか?ありがとう。

+1

:あなたは、スカラー副問合せを必要としません。 – wildplasser

+2

Postgresは、番号付きプレースホルダ、すなわち '$ 1'でしか動作しないと私は思っていました。 –

+1

pgsqlを扱うのにどのドライバパッケージを使用していますか?ご存じのように、Goには標準ライブラリにRDBMS用のドライバが含まれていないので、何をしているのかを教えておくことが不可欠です。 'github.com/lib/pq'を使用している場合、[the docs](https://godoc.org/github.com/lib/pq)には、@ Ainar- Gが提案した。 IOWでは、クエリプレースホルダの形式はドライバ固有であり、普遍的なものではありません。 – kostix

答えて

0

移動先では対応していません。

あなたは(docsから)SQLXを使用してこの機能

例をしたい場合は、jmoiron/sqlxを使用することができます無関係

var levels = []int{4, 6, 7} 
query, args, err := sqlx.In("SELECT * FROM users WHERE level IN (?);", levels) 

// sqlx.In returns queries with the `?` bindvar, we can rebind it for our backend 
query = db.Rebind(query) 
rows, err := db.Query(query, args...) 
関連する問題