mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 02:46:29 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| 
 | |
| select json_equals("{}", "{}");
 | |
| 
 | |
| select json_equals("{}", "[]");
 | |
| 
 | |
| select json_equals("{}", NULL);
 | |
| 
 | |
| select json_equals("", "");
 | |
| 
 | |
| select json_equals("", 1);
 | |
| 
 | |
| select json_equals(now(), now());
 | |
| 
 | |
| select json_equals('{"a":[1, 2, 3]}', '{"a":[1, 2, 3, 4]}');
 | |
| 
 | |
| select json_equals('{"a":[1, 2, 3]}', '{"a":[1, 2, 3]}');
 | |
| 
 | |
| select json_equals('{"țanțoș":[1, 2, "ț", {"some uâ߀":"uâßr"}]}',
 | |
|                    '{"țanțoș":[1, 2, "ț", {"some uâ߀":"uâßr"}]}') as je;
 | |
| 
 | |
| select json_equals('{"a" : [0.123456789123456789], "b" : [1, 2, 3]}',
 | |
|                    '{"b" : [1, 2, 3], "a" : [0.123456789123456789]}') as je;
 | |
| 
 | |
| --echo #
 | |
| --echo # Test max json depth for json_equals.
 | |
| --echo #
 | |
| with recursive rec_json (step, obj) as (
 | |
|   select 1, cast('{"key":"value"}' as varchar(1000))
 | |
|   union
 | |
|   select r.step + 1, JSON_INSERT('{}', '$.obj', JSON_QUERY(r.obj, '$'))
 | |
|   from rec_json r
 | |
|   where r.step < 10
 | |
| )
 | |
| select step, obj, json_equals(obj, obj) from rec_json;
 | |
| 
 | |
| --echo #
 | |
| --echo # 31 levels of nesting.
 | |
| --echo #
 | |
| select json_equals('{"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"key": "value"}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}',
 | |
| '{"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"key": "value"}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}') as 31_levels;
 | |
| 
 | |
| --echo #
 | |
| --echo # 32 Levels of nesting. This should hit max json depth.
 | |
| --echo #
 | |
| select json_equals('{"obj":{"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"key": "value"}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}',
 | |
| '{"obj":{"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"obj": {"key": "value"}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}') as 32_levels;
 | |
| 
 | |
| 
 | |
| --echo #
 | |
| --echo # test values from different charset
 | |
| --echo # (UTF-8 two-bytes vs. latin1 single high-byte)
 | |
| --echo #
 | |
| create table t1 (a varchar(200) character set latin1);
 | |
| create table t2 (a varchar(200) character set utf8);
 | |
| insert into t1 values (UNHEX('22CA22'));
 | |
| set names utf8;
 | |
| insert into t2 values (UNHEX('22C38A22'));
 | |
| 
 | |
| select a from t1;
 | |
| select hex(a) from t1;
 | |
| select a from t2;
 | |
| select hex(a) from t2;
 | |
| 
 | |
| select t1.a, t2.a, t1.a = t2.a,
 | |
|        json_valid(t1.a), json_valid(t2.a), json_equals(t1.a, t2.a)
 | |
| from t1, t2;
 | |
| 
 | |
| drop table t1;
 | |
| drop table t2;
 | 
