微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当实体ID包含特殊字符时,Fiware Cygnus PostgreSQL接收器不会创建表

如何解决当实体ID包含特殊字符时,Fiware Cygnus PostgreSQL接收器不会创建表

似乎 cygnus-ngsi 及其Posgresql接收器无法在实体的ID包含-字符(例如)的情况下创建postgres表。 the Fiware tutorials中推荐的urn:ngsi-ld:Motion:001

我使用Orion,IoT-Agent以及Cygnus-NGSI和Postgresql数据库设置了一个简单的堆栈。

但是,Postgresql报告错误

2020-11-10 08:39:33.404 UTC [66] ERROR: Syntax error at or near "-" at character 44
2020-11-10 08:39:33.404 UTC [66] STATEMENT: CREATE TABLE IF NOT EXISTS openiot.urn_ngsi-ld_motion_001_thing (recvTimeTs text,recvTime text,fiwareServicePath text,entityId text,entityType text,attrName text,attrType text,attrValue text,attrMd text)

使用其他实体ID时不会发生此错误。 然后数据将按预期保存。

天鹅座should replace non-alphanumeric characters inentity ids with _,但是,这似乎没有发生。 这是一个错误还是我需要某种name mapping才能解决此问题?

解决方法

encoding section in the Postgresql sink documentation 来看,似乎没有对 - 进行特殊编码。

因此,- 按照 Postgresql 表创建逻辑的方式进行并引发错误,因为数据库禁止在表名中使用它。

您可以探索名称映射选项(尽管我不确定您是否可以使用它更改实体 ID...)。另一种可能的解决方法(非常简单)不在实体 ID 中使用 -,例如:urn:ngsild:Motion:001

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。