如何在H2 JSON FIELD中禁用JSON逃脱

发布于 2025-01-29 19:40:16 字数 765 浏览 4 评论 0原文

以下代码

DROP TABLE IF EXISTS  BBB;

CREATE TABLE BBB (id INT, data1 JSON, data2 TEXT);

insert into BBB (id, data1, data2) VALUES
(1, '{"a": 12}', '{"a": 12}');

SELECT *, CAST(data1 as TEXT) data3 FROM BBB;

在MySQL和H2中导致不同的结果。

在H2中,它显示

“在此处输入图像描述”

当在mysql中显示

”在此处输入图像说明“

ie h2添加了未经口气的逃脱。如何(可以)使H2的行为与mySQL IE json fields的逃逸相同?

同样对JPA/Hibernate进行解决方案也非常感谢。

The following code

DROP TABLE IF EXISTS  BBB;

CREATE TABLE BBB (id INT, data1 JSON, data2 TEXT);

insert into BBB (id, data1, data2) VALUES
(1, '{"a": 12}', '{"a": 12}');

SELECT *, CAST(data1 as TEXT) data3 FROM BBB;

causes different results in MySQL and H2.

In H2 it shows

enter image description here

while in MySQL it shows

enter image description here

I.e. H2 adds unneded escaping. How to (is it possible to) make H2 to behave the same as MySQL i.e. disable escaping of JSON fields?

Also workarounds with JPA/Hibernate are appreciated.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

你曾走过我的故事 2025-02-05 19:40:16

我将字段类型更改为文本,一切都按照我的预期工作:

CREATE TABLE BBB (id INT, data1 TEXT, data2 TEXT);

I've changed the field type to text, and everything is working as expected for me:

CREATE TABLE BBB (id INT, data1 TEXT, data2 TEXT);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文