我有以下表中PostgreSQL的定义:
通过杰克逊
Column | Type | Modifiers
-----------------+------------------------+-----------
id | uuid | not null
entity_snapshot | text |
Indexes:
"pk_id" PRIMARY KEY, btree (id)
我想存储以下JSON字符串:
[ "org.test.MyUniqueId", {: "uuid" : "f4b40050-9716-4346-bf84-8325fadd9876": } ]
对于一些测试,而不是这样做使用杰克逊,我尝试手动键入一个SQL,这里是我的问题 - 我似乎无法得到正确的。
我现在的尝试是:
insert into my_table(id,entity_snapshot) values ('d11d944e-6e78-11e1-aae1-52540015fc3f','[ \"org.test.MyUniqueId\", {: \"uuid\" : \"f4b40050-9716-4346-bf84-8325fadd9876\": } ]');
Procuedure看起来像什么,我需要当我从表中选择,但是当我尝试使用杰克逊解析它,我得到一个错误的纪录 -
org.apache.commons.lang.SerializationException: org.codehaus.jackson.JsonParseException: Unexpected character (':' (code 58)): was expecting double-quote to start field name
不用说,如果通过我的java代码插入相同的记录,我可以解析它,当涉及到用人眼来查看记录时,它对我来说看起来是一样的。
你能告诉我在我的SQL插入语句中我错了吗?
您可以使用sqldump写在Java插入行和手动文本文件和比较什么是与手动插入不同。 –