[英]Prepared insert statement in node.js using pg and postgresqlDB
我正在尝试将 Polygon 写入我的 Postgresql 数据库。 Postgis 已安装,我尝试执行示例语句并且它正在工作。 到目前为止,一切都很好。
这是我的例子:
INSERT INTO assets VALUES('test', 'test2id', 210, ST_Polygon('LINESTRING(16.0 14.0, 20.0 14.0, 20.0 12.0, 16.0 12.0,16.0 14.0)':: geometry, 4326), 'Crime');
所以我尝试在准备好的语句中转换它,我的代码如下所示:
const Pool = require('pg').Pool
const pool = new Pool({
user: process.env.DB_USER,
host: process.env.DB_HOST,
database: process.env.DB_DATABASE,
password: process.env.DB_PASSWORD,
port: process.env.DB_PORT,
})
const sql = "INSERT INTO assets (title, id, duration, geodata, genre) VALUES($1, $2, $3, $4, $5);"
const values = [title, crid, duration, poly_string, genre]
pool.query(sql, values, (error, results) => {
if (error) {
response.status(500).send("Internal Server Error")
throw error
}
})
变量的值是这样的:
poly_string = "ST_Polygon('LINESTRING(16 14, 20 14, 20 12, 16 12, 16 14)':: geometry, 4326)"
title = "test"
id = "IHSJSKLANSHKLSHJSMSNSD"
duration = 1290
genre = "crime"
如果我运行代码,我会收到以下错误:
error: parse error - invalid geometry
length: 147,
severity: 'ERROR',
code: 'XX000',
detail: undefined,
hint: '"ST" <-- parse error at position 2 within geometry',
感谢您提供任何帮助或想法。 :)
Hy Oivalf,我有同样的情况,但我的情况是查询更新,这里是我的示例查询
const updatePole =
'UPDATE public."Pole" SET geom = $1, status = $2, WHERE id = $3'
当我在表格上处理表单数据时效果很好,但是当我在地图上进行更改时它不起作用,并使数据值为null
。 我尝试使用此代码
const updatePole =
'UPDATE public."Pole" SET geom = ST_AsGeoJSON($1,4326::integer), status = $2, WHERE id = $3'
它对我有用。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.