PreparedStatement并未读取我的PostGIS Geography的所有参数

|| 我有以下JDBC代码。请注意,我正在尝试使用PostGIS地理环境:
PreparedStatement stmt = db.prepareStatement(\"INSERT INTO \" +
                    \"source_imagery (image_path, boundary, image_time)\" +
                    \" VALUES (?, ST_GeographyFromText(\'POLYGON((\" +
                    \"? ?, ? ?, ? ?, ? ?))\'), ?)\");

            stmt.setString(1, file.getAbsolutePath());
            stmt.setDouble(2, bounds.getY());
            stmt.setDouble(3, bounds.getX());
            ...
我在代码的最后一行收到以下异常:
org.postgresql.util.PSQLException: The column index is out of range: 3, number of columns: 2.
我知道它认为那里只有2个参数,但是您可以看到我打算有2个参数。我不确定为什么它不读取
POLYGON
中的任何参数。我知道,如果我直接在数据库中使用此SQL语句,它将起作用,但是我不确定为使它在Java代码中起作用而必须更改的内容。有任何想法吗?     
已邀请:
        您的问题是这样的:
\'POLYGON((? ?, ? ?, ? ?, ? ?))\'
是一个SQL字符串文字,恰好包含八个问号。由于这是SQL字符串文字,因此其中的任何问号均不视为占位符。这给您留下了两个占位符:一个在
VALUES
列表的开头,另一个在末尾。 您将不得不以其他方式构建多边形。可能有比ѭ5更好的方法,但是,las,我不知道它是什么,而且我也没有在任何地方设置PostGIS。如有必要,您可以使用标准字符串处理来手动构建POLYGON字符串,然后为其使用占位符:
VALUES (?, ST_GeographyFromText(?), ?)
ST_GeographyFromText
内的占位符将被视为占位符,因为它不在字符串文字中,您可以使用
stmt.setString
为其提供值。     
        由于mu正确地表示的太短,问题在于在引号内无法识别占位符。 如果无法在Java中构建整个字符串(例如,在我看来太过侵入),则可以通过将占位符移到文字之外然后使用PgSQL字符串连接运算符来解决此问题,如下所示:
ST_GeographyFromText(\'SRID=4326;POINT(\' || ? || \' \' || ? || \')\')
您的解决方案是:
ST_GeographyFromText(\'POLYGON((\' || ? || \' \' || ? || \', \' || ? || \' \' || ? ||
    \', \' || ? || \' \' || ? || \', \' || ? || \'\' || ? || \'))\')
不太可读,但是可以用...     

要回复问题请先登录注册