@@ -1833,3 +1833,166 @@ SELECT jsonb_path_match('[{"a": 1}, {"a": 2}]', '$[*].a > 1');
18331833 t
18341834(1 row)
18351835
1836+ -- test string comparison (Unicode codepoint collation)
1837+ WITH str(j, num) AS
1838+ (
1839+ SELECT jsonb_build_object('s', s), num
1840+ FROM unnest('{"", "a", "ab", "abc", "abcd", "b", "A", "AB", "ABC", "ABc", "ABcD", "B"}'::text[]) WITH ORDINALITY AS a(s, num)
1841+ )
1842+ SELECT
1843+ s1.j, s2.j,
1844+ jsonb_path_query_first(s1.j, '$.s < $s', vars => s2.j) lt,
1845+ jsonb_path_query_first(s1.j, '$.s <= $s', vars => s2.j) le,
1846+ jsonb_path_query_first(s1.j, '$.s == $s', vars => s2.j) eq,
1847+ jsonb_path_query_first(s1.j, '$.s >= $s', vars => s2.j) ge,
1848+ jsonb_path_query_first(s1.j, '$.s > $s', vars => s2.j) gt
1849+ FROM str s1, str s2
1850+ ORDER BY s1.num, s2.num;
1851+ j | j | lt | le | eq | ge | gt
1852+ ---------------+---------------+-------+-------+-------+-------+-------
1853+ {"s": ""} | {"s": ""} | false | true | true | true | false
1854+ {"s": ""} | {"s": "a"} | true | true | false | false | false
1855+ {"s": ""} | {"s": "ab"} | true | true | false | false | false
1856+ {"s": ""} | {"s": "abc"} | true | true | false | false | false
1857+ {"s": ""} | {"s": "abcd"} | true | true | false | false | false
1858+ {"s": ""} | {"s": "b"} | true | true | false | false | false
1859+ {"s": ""} | {"s": "A"} | true | true | false | false | false
1860+ {"s": ""} | {"s": "AB"} | true | true | false | false | false
1861+ {"s": ""} | {"s": "ABC"} | true | true | false | false | false
1862+ {"s": ""} | {"s": "ABc"} | true | true | false | false | false
1863+ {"s": ""} | {"s": "ABcD"} | true | true | false | false | false
1864+ {"s": ""} | {"s": "B"} | true | true | false | false | false
1865+ {"s": "a"} | {"s": ""} | false | false | false | true | true
1866+ {"s": "a"} | {"s": "a"} | false | true | true | true | false
1867+ {"s": "a"} | {"s": "ab"} | true | true | false | false | false
1868+ {"s": "a"} | {"s": "abc"} | true | true | false | false | false
1869+ {"s": "a"} | {"s": "abcd"} | true | true | false | false | false
1870+ {"s": "a"} | {"s": "b"} | true | true | false | false | false
1871+ {"s": "a"} | {"s": "A"} | false | false | false | true | true
1872+ {"s": "a"} | {"s": "AB"} | false | false | false | true | true
1873+ {"s": "a"} | {"s": "ABC"} | false | false | false | true | true
1874+ {"s": "a"} | {"s": "ABc"} | false | false | false | true | true
1875+ {"s": "a"} | {"s": "ABcD"} | false | false | false | true | true
1876+ {"s": "a"} | {"s": "B"} | false | false | false | true | true
1877+ {"s": "ab"} | {"s": ""} | false | false | false | true | true
1878+ {"s": "ab"} | {"s": "a"} | false | false | false | true | true
1879+ {"s": "ab"} | {"s": "ab"} | false | true | true | true | false
1880+ {"s": "ab"} | {"s": "abc"} | true | true | false | false | false
1881+ {"s": "ab"} | {"s": "abcd"} | true | true | false | false | false
1882+ {"s": "ab"} | {"s": "b"} | true | true | false | false | false
1883+ {"s": "ab"} | {"s": "A"} | false | false | false | true | true
1884+ {"s": "ab"} | {"s": "AB"} | false | false | false | true | true
1885+ {"s": "ab"} | {"s": "ABC"} | false | false | false | true | true
1886+ {"s": "ab"} | {"s": "ABc"} | false | false | false | true | true
1887+ {"s": "ab"} | {"s": "ABcD"} | false | false | false | true | true
1888+ {"s": "ab"} | {"s": "B"} | false | false | false | true | true
1889+ {"s": "abc"} | {"s": ""} | false | false | false | true | true
1890+ {"s": "abc"} | {"s": "a"} | false | false | false | true | true
1891+ {"s": "abc"} | {"s": "ab"} | false | false | false | true | true
1892+ {"s": "abc"} | {"s": "abc"} | false | true | true | true | false
1893+ {"s": "abc"} | {"s": "abcd"} | true | true | false | false | false
1894+ {"s": "abc"} | {"s": "b"} | true | true | false | false | false
1895+ {"s": "abc"} | {"s": "A"} | false | false | false | true | true
1896+ {"s": "abc"} | {"s": "AB"} | false | false | false | true | true
1897+ {"s": "abc"} | {"s": "ABC"} | false | false | false | true | true
1898+ {"s": "abc"} | {"s": "ABc"} | false | false | false | true | true
1899+ {"s": "abc"} | {"s": "ABcD"} | false | false | false | true | true
1900+ {"s": "abc"} | {"s": "B"} | false | false | false | true | true
1901+ {"s": "abcd"} | {"s": ""} | false | false | false | true | true
1902+ {"s": "abcd"} | {"s": "a"} | false | false | false | true | true
1903+ {"s": "abcd"} | {"s": "ab"} | false | false | false | true | true
1904+ {"s": "abcd"} | {"s": "abc"} | false | false | false | true | true
1905+ {"s": "abcd"} | {"s": "abcd"} | false | true | true | true | false
1906+ {"s": "abcd"} | {"s": "b"} | true | true | false | false | false
1907+ {"s": "abcd"} | {"s": "A"} | false | false | false | true | true
1908+ {"s": "abcd"} | {"s": "AB"} | false | false | false | true | true
1909+ {"s": "abcd"} | {"s": "ABC"} | false | false | false | true | true
1910+ {"s": "abcd"} | {"s": "ABc"} | false | false | false | true | true
1911+ {"s": "abcd"} | {"s": "ABcD"} | false | false | false | true | true
1912+ {"s": "abcd"} | {"s": "B"} | false | false | false | true | true
1913+ {"s": "b"} | {"s": ""} | false | false | false | true | true
1914+ {"s": "b"} | {"s": "a"} | false | false | false | true | true
1915+ {"s": "b"} | {"s": "ab"} | false | false | false | true | true
1916+ {"s": "b"} | {"s": "abc"} | false | false | false | true | true
1917+ {"s": "b"} | {"s": "abcd"} | false | false | false | true | true
1918+ {"s": "b"} | {"s": "b"} | false | true | true | true | false
1919+ {"s": "b"} | {"s": "A"} | false | false | false | true | true
1920+ {"s": "b"} | {"s": "AB"} | false | false | false | true | true
1921+ {"s": "b"} | {"s": "ABC"} | false | false | false | true | true
1922+ {"s": "b"} | {"s": "ABc"} | false | false | false | true | true
1923+ {"s": "b"} | {"s": "ABcD"} | false | false | false | true | true
1924+ {"s": "b"} | {"s": "B"} | false | false | false | true | true
1925+ {"s": "A"} | {"s": ""} | false | false | false | true | true
1926+ {"s": "A"} | {"s": "a"} | true | true | false | false | false
1927+ {"s": "A"} | {"s": "ab"} | true | true | false | false | false
1928+ {"s": "A"} | {"s": "abc"} | true | true | false | false | false
1929+ {"s": "A"} | {"s": "abcd"} | true | true | false | false | false
1930+ {"s": "A"} | {"s": "b"} | true | true | false | false | false
1931+ {"s": "A"} | {"s": "A"} | false | true | true | true | false
1932+ {"s": "A"} | {"s": "AB"} | true | true | false | false | false
1933+ {"s": "A"} | {"s": "ABC"} | true | true | false | false | false
1934+ {"s": "A"} | {"s": "ABc"} | true | true | false | false | false
1935+ {"s": "A"} | {"s": "ABcD"} | true | true | false | false | false
1936+ {"s": "A"} | {"s": "B"} | true | true | false | false | false
1937+ {"s": "AB"} | {"s": ""} | false | false | false | true | true
1938+ {"s": "AB"} | {"s": "a"} | true | true | false | false | false
1939+ {"s": "AB"} | {"s": "ab"} | true | true | false | false | false
1940+ {"s": "AB"} | {"s": "abc"} | true | true | false | false | false
1941+ {"s": "AB"} | {"s": "abcd"} | true | true | false | false | false
1942+ {"s": "AB"} | {"s": "b"} | true | true | false | false | false
1943+ {"s": "AB"} | {"s": "A"} | false | false | false | true | true
1944+ {"s": "AB"} | {"s": "AB"} | false | true | true | true | false
1945+ {"s": "AB"} | {"s": "ABC"} | true | true | false | false | false
1946+ {"s": "AB"} | {"s": "ABc"} | true | true | false | false | false
1947+ {"s": "AB"} | {"s": "ABcD"} | true | true | false | false | false
1948+ {"s": "AB"} | {"s": "B"} | true | true | false | false | false
1949+ {"s": "ABC"} | {"s": ""} | false | false | false | true | true
1950+ {"s": "ABC"} | {"s": "a"} | true | true | false | false | false
1951+ {"s": "ABC"} | {"s": "ab"} | true | true | false | false | false
1952+ {"s": "ABC"} | {"s": "abc"} | true | true | false | false | false
1953+ {"s": "ABC"} | {"s": "abcd"} | true | true | false | false | false
1954+ {"s": "ABC"} | {"s": "b"} | true | true | false | false | false
1955+ {"s": "ABC"} | {"s": "A"} | false | false | false | true | true
1956+ {"s": "ABC"} | {"s": "AB"} | false | false | false | true | true
1957+ {"s": "ABC"} | {"s": "ABC"} | false | true | true | true | false
1958+ {"s": "ABC"} | {"s": "ABc"} | true | true | false | false | false
1959+ {"s": "ABC"} | {"s": "ABcD"} | true | true | false | false | false
1960+ {"s": "ABC"} | {"s": "B"} | true | true | false | false | false
1961+ {"s": "ABc"} | {"s": ""} | false | false | false | true | true
1962+ {"s": "ABc"} | {"s": "a"} | true | true | false | false | false
1963+ {"s": "ABc"} | {"s": "ab"} | true | true | false | false | false
1964+ {"s": "ABc"} | {"s": "abc"} | true | true | false | false | false
1965+ {"s": "ABc"} | {"s": "abcd"} | true | true | false | false | false
1966+ {"s": "ABc"} | {"s": "b"} | true | true | false | false | false
1967+ {"s": "ABc"} | {"s": "A"} | false | false | false | true | true
1968+ {"s": "ABc"} | {"s": "AB"} | false | false | false | true | true
1969+ {"s": "ABc"} | {"s": "ABC"} | false | false | false | true | true
1970+ {"s": "ABc"} | {"s": "ABc"} | false | true | true | true | false
1971+ {"s": "ABc"} | {"s": "ABcD"} | true | true | false | false | false
1972+ {"s": "ABc"} | {"s": "B"} | true | true | false | false | false
1973+ {"s": "ABcD"} | {"s": ""} | false | false | false | true | true
1974+ {"s": "ABcD"} | {"s": "a"} | true | true | false | false | false
1975+ {"s": "ABcD"} | {"s": "ab"} | true | true | false | false | false
1976+ {"s": "ABcD"} | {"s": "abc"} | true | true | false | false | false
1977+ {"s": "ABcD"} | {"s": "abcd"} | true | true | false | false | false
1978+ {"s": "ABcD"} | {"s": "b"} | true | true | false | false | false
1979+ {"s": "ABcD"} | {"s": "A"} | false | false | false | true | true
1980+ {"s": "ABcD"} | {"s": "AB"} | false | false | false | true | true
1981+ {"s": "ABcD"} | {"s": "ABC"} | false | false | false | true | true
1982+ {"s": "ABcD"} | {"s": "ABc"} | false | false | false | true | true
1983+ {"s": "ABcD"} | {"s": "ABcD"} | false | true | true | true | false
1984+ {"s": "ABcD"} | {"s": "B"} | true | true | false | false | false
1985+ {"s": "B"} | {"s": ""} | false | false | false | true | true
1986+ {"s": "B"} | {"s": "a"} | true | true | false | false | false
1987+ {"s": "B"} | {"s": "ab"} | true | true | false | false | false
1988+ {"s": "B"} | {"s": "abc"} | true | true | false | false | false
1989+ {"s": "B"} | {"s": "abcd"} | true | true | false | false | false
1990+ {"s": "B"} | {"s": "b"} | true | true | false | false | false
1991+ {"s": "B"} | {"s": "A"} | false | false | false | true | true
1992+ {"s": "B"} | {"s": "AB"} | false | false | false | true | true
1993+ {"s": "B"} | {"s": "ABC"} | false | false | false | true | true
1994+ {"s": "B"} | {"s": "ABc"} | false | false | false | true | true
1995+ {"s": "B"} | {"s": "ABcD"} | false | false | false | true | true
1996+ {"s": "B"} | {"s": "B"} | false | true | true | true | false
1997+ (144 rows)
1998+
0 commit comments