繁体   English   中英

使用 pg 和 postgresqlDB 在 node.js 中准备插入语句

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM