1
0
mirror of https://github.com/mariadb-corporation/mariadb-columnstore-engine.git synced 2025-10-31 18:30:33 +03:00
Files
mariadb-columnstore-engine/mysql-test/columnstore/basic/t/func_json_contains.test
Rucha Deodhar 9fe37d5919 MDEV-32854: Make JSON_DEPTH_LIMIT unlimited
This patch is the columnstore-part of the task. Columnstore wanted to have
previous 32 depth, so this patch aims at keeping the compatibility.
2025-09-14 17:16:17 +04:00

61 lines
1.9 KiB
Plaintext

--source ../include/have_columnstore.inc
--disable_warnings
DROP DATABASE IF EXISTS json_contains_db;
--enable_warnings
CREATE DATABASE json_contains_db;
USE json_contains_db;
--echo # ----------------------------------------------------------------------
--echo # Test of JSON_CONTAINS function.
--echo # ----------------------------------------------------------------------
CREATE TABLE t1(j LONGTEXT, v LONGTEXT, p LONGTEXT) ENGINE = columnstore;
INSERT INTO t1 VALUES ('{"k1":123, "k2":345}', '123', '$.k1');
INSERT INTO t1 VALUES ('', '', '$');
INSERT INTO t1 VALUES ('null', 'null', '$');
INSERT INTO t1 VALUES ('"10"', '"10"', '$');
INSERT INTO t1 VALUES ('"10"', '10', '$');
INSERT INTO t1 VALUES ('10.1', '10', '$');
INSERT INTO t1 VALUES ('10.0', '10', '$');
SELECT
j AS json,
v AS value,
p AS path,
JSON_CONTAINS(j, v, p) AS result
FROM
t1;
CREATE TABLE t2(j LONGTEXT, v LONGTEXT) ENGINE = columnstore;
INSERT INTO t2 VALUES ('"you"', '"you"');
INSERT INTO t2 VALUES ('"youth"', '"you"');
INSERT INTO t2 VALUES ('[1]', '1');
INSERT INTO t2 VALUES ('[2, 1]', '1');
INSERT INTO t2 VALUES ('[2, [2, 3], 1]', '1');
INSERT INTO t2 VALUES ('[4, [2, 3], 1]', '2');
INSERT INTO t2 VALUES ('[2, 1]', '[1, 2]');
INSERT INTO t2 VALUES ('[2, 1]', '[1, 0, 2]');
INSERT INTO t2 VALUES ('[2, 0, 3, 1]', '[1, 2]');
INSERT INTO t2 VALUES ('{"b":[1,2], "a":1}', '{"a":1, "b":2}');
INSERT INTO t2 VALUES ('{"a":1}', '{}');
INSERT INTO t2 VALUES ('[1, {"a":1}]', '{}');
INSERT INTO t2 VALUES ('[1, {"a":1}]', '{"a":1}');
INSERT INTO t2 VALUES ('[{"abc":"def", "def":"abc"}]', '["foo","bar"]');
INSERT INTO t2 VALUES ('[{"abc":"def", "def":"abc"}, "bar"]', '["bar", {}]');
INSERT INTO t2 VALUES ('[{"a":"b"},{"c":"d"}]', '{"c":"d"}');
SELECT
j AS json,
v AS value,
JSON_CONTAINS(j, v) AS result
FROM
t2;
DROP TABLE t2;
DROP TABLE t1;
DROP DATABASE json_contains_db;