mirror of
https://github.com/MariaDB/server.git
synced 2025-01-15 19:42:28 +01:00
Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20
In MySQL when the mapping for space is changed to something other than 0x20 by defining a different collation, then space is not ignored when comparing two strings. This was happening because the function that performs the comparison of two strings while ignoring ending spaces, was comparing the collation value of a space with the ascii value of the ' ' character. This should be changed to do comparison between the collated values. mysql-test/r/ctype_ldml.result: Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20 Result file for test case. mysql-test/std_data/Index.xml: Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20 Added entry for new test collation in the index file. mysql-test/std_data/latin1.xml: Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20 Added support for new collation for test. mysql-test/t/ctype_ldml.test: Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20 Added test case to ensure trailing spaces are not ignored. strings/ctype-simple.c: Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20 change my_strnncollsp_simple to compare collated values when checking for trailing spaces. Currently the comparison happens between a collated value and the ascii value.
This commit is contained in:
parent
f1c2f6e84e
commit
64e89a7ed2
5 changed files with 163 additions and 2 deletions
|
@ -321,3 +321,11 @@ Vv
|
||||||
Xx
|
Xx
|
||||||
YyÝýỲỳỴỵỶỷỸỹ
|
YyÝýỲỳỴỵỶỷỸỹ
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20
|
||||||
|
set names latin1;
|
||||||
|
show collation like 'latin1_test';
|
||||||
|
Collation Charset Id Default Compiled Sortlen
|
||||||
|
latin1_test latin1 99 Yes 1
|
||||||
|
select "foo" = "foo " collate latin1_test;
|
||||||
|
"foo" = "foo " collate latin1_test
|
||||||
|
1
|
||||||
|
|
|
@ -68,4 +68,17 @@
|
||||||
|
|
||||||
</charset>
|
</charset>
|
||||||
|
|
||||||
|
<charset name="latin1">
|
||||||
|
<family>Western</family>
|
||||||
|
<description>cp1252 West European</description>
|
||||||
|
<alias>csisolatin1</alias>
|
||||||
|
<alias>iso-8859-1</alias>
|
||||||
|
<alias>iso-ir-100</alias>
|
||||||
|
<alias>iso_8859-1</alias>
|
||||||
|
<alias>iso_8859-1:1987</alias>
|
||||||
|
<alias>l1</alias>
|
||||||
|
<alias>latin1</alias>
|
||||||
|
<collation name="latin1_test" id="99" order="test"/>
|
||||||
|
</charset>
|
||||||
|
|
||||||
</charsets>
|
</charsets>
|
||||||
|
|
135
mysql-test/std_data/latin1.xml
Normal file
135
mysql-test/std_data/latin1.xml
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
<?xml version='1.0' encoding="utf-8"?>
|
||||||
|
|
||||||
|
<charsets>
|
||||||
|
|
||||||
|
<copyright>
|
||||||
|
Copyright (C) 2003 MySQL AB
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; version 2 of the License.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
</copyright>
|
||||||
|
|
||||||
|
<charset name="latin1">
|
||||||
|
|
||||||
|
<ctype>
|
||||||
|
<map>
|
||||||
|
00
|
||||||
|
20 20 20 20 20 20 20 20 20 28 28 28 28 28 20 20
|
||||||
|
20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
|
||||||
|
48 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10
|
||||||
|
84 84 84 84 84 84 84 84 84 84 10 10 10 10 10 10
|
||||||
|
10 81 81 81 81 81 81 01 01 01 01 01 01 01 01 01
|
||||||
|
01 01 01 01 01 01 01 01 01 01 01 10 10 10 10 10
|
||||||
|
10 82 82 82 82 82 82 02 02 02 02 02 02 02 02 02
|
||||||
|
02 02 02 02 02 02 02 02 02 02 02 10 10 10 10 20
|
||||||
|
10 00 10 02 10 10 10 10 10 10 01 10 01 00 01 00
|
||||||
|
00 10 10 10 10 10 10 10 10 10 02 10 02 00 02 01
|
||||||
|
48 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10
|
||||||
|
10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10
|
||||||
|
01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01
|
||||||
|
01 01 01 01 01 01 01 10 01 01 01 01 01 01 01 02
|
||||||
|
02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02
|
||||||
|
02 02 02 02 02 02 02 10 02 02 02 02 02 02 02 02
|
||||||
|
</map>
|
||||||
|
</ctype>
|
||||||
|
|
||||||
|
|
||||||
|
<lower>
|
||||||
|
<map>
|
||||||
|
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
|
||||||
|
10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F
|
||||||
|
20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F
|
||||||
|
30 31 32 33 34 35 36 37 38 39 3A 3B 3C 3D 3E 3F
|
||||||
|
40 61 62 63 64 65 66 67 68 69 6A 6B 6C 6D 6E 6F
|
||||||
|
70 71 72 73 74 75 76 77 78 79 7A 5B 5C 5D 5E 5F
|
||||||
|
60 61 62 63 64 65 66 67 68 69 6A 6B 6C 6D 6E 6F
|
||||||
|
70 71 72 73 74 75 76 77 78 79 7A 7B 7C 7D 7E 7F
|
||||||
|
80 81 82 83 84 85 86 87 88 89 8A 8B 8C 8D 8E 8F
|
||||||
|
90 91 92 93 94 95 96 97 98 99 9A 9B 9C 9D 9E 9F
|
||||||
|
A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 AA AB AC AD AE AF
|
||||||
|
B0 B1 B2 B3 B4 B5 B6 B7 B8 B9 BA BB BC BD BE BF
|
||||||
|
E0 E1 E2 E3 E4 E5 E6 E7 E8 E9 EA EB EC ED EE EF
|
||||||
|
F0 F1 F2 F3 F4 F5 F6 D7 F8 F9 FA FB FC FD FE DF
|
||||||
|
E0 E1 E2 E3 E4 E5 E6 E7 E8 E9 EA EB EC ED EE EF
|
||||||
|
F0 F1 F2 F3 F4 F5 F6 F7 F8 F9 FA FB FC FD FE FF
|
||||||
|
</map>
|
||||||
|
</lower>
|
||||||
|
|
||||||
|
|
||||||
|
<upper>
|
||||||
|
<map>
|
||||||
|
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
|
||||||
|
10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F
|
||||||
|
20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F
|
||||||
|
30 31 32 33 34 35 36 37 38 39 3A 3B 3C 3D 3E 3F
|
||||||
|
40 41 42 43 44 45 46 47 48 49 4A 4B 4C 4D 4E 4F
|
||||||
|
50 51 52 53 54 55 56 57 58 59 5A 5B 5C 5D 5E 5F
|
||||||
|
60 41 42 43 44 45 46 47 48 49 4A 4B 4C 4D 4E 4F
|
||||||
|
50 51 52 53 54 55 56 57 58 59 5A 7B 7C 7D 7E 7F
|
||||||
|
80 81 82 83 84 85 86 87 88 89 8A 8B 8C 8D 8E 8F
|
||||||
|
90 91 92 93 94 95 96 97 98 99 9A 9B 9C 9D 9E 9F
|
||||||
|
A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 AA AB AC AD AE AF
|
||||||
|
B0 B1 B2 B3 B4 B5 B6 B7 B8 B9 BA BB BC BD BE BF
|
||||||
|
C0 C1 C2 C3 C4 C5 C6 C7 C8 C9 CA CB CC CD CE CF
|
||||||
|
D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 DA DB DC DD DE DF
|
||||||
|
C0 C1 C2 C3 C4 C5 C6 C7 C8 C9 CA CB CC CD CE CF
|
||||||
|
D0 D1 D2 D3 D4 D5 D6 F7 D8 D9 DA DB DC DD DE FF
|
||||||
|
</map>
|
||||||
|
</upper>
|
||||||
|
|
||||||
|
|
||||||
|
<unicode>
|
||||||
|
<map>
|
||||||
|
0000 0001 0002 0003 0004 0005 0006 0007 0008 0009 000A 000B 000C 000D 000E 000F
|
||||||
|
0010 0011 0012 0013 0014 0015 0016 0017 0018 0019 001A 001B 001C 001D 001E 001F
|
||||||
|
0020 0021 0022 0023 0024 0025 0026 0027 0028 0029 002A 002B 002C 002D 002E 002F
|
||||||
|
0030 0031 0032 0033 0034 0035 0036 0037 0038 0039 003A 003B 003C 003D 003E 003F
|
||||||
|
0040 0041 0042 0043 0044 0045 0046 0047 0048 0049 004A 004B 004C 004D 004E 004F
|
||||||
|
0050 0051 0052 0053 0054 0055 0056 0057 0058 0059 005A 005B 005C 005D 005E 005F
|
||||||
|
0060 0061 0062 0063 0064 0065 0066 0067 0068 0069 006A 006B 006C 006D 006E 006F
|
||||||
|
0070 0071 0072 0073 0074 0075 0076 0077 0078 0079 007A 007B 007C 007D 007E 007F
|
||||||
|
20AC 0081 201A 0192 201E 2026 2020 2021 02C6 2030 0160 2039 0152 008D 017D 008F
|
||||||
|
0090 2018 2019 201C 201D 2022 2013 2014 02DC 2122 0161 203A 0153 009D 017E 0178
|
||||||
|
00A0 00A1 00A2 00A3 00A4 00A5 00A6 00A7 00A8 00A9 00AA 00AB 00AC 00AD 00AE 00AF
|
||||||
|
00B0 00B1 00B2 00B3 00B4 00B5 00B6 00B7 00B8 00B9 00BA 00BB 00BC 00BD 00BE 00BF
|
||||||
|
00C0 00C1 00C2 00C3 00C4 00C5 00C6 00C7 00C8 00C9 00CA 00CB 00CC 00CD 00CE 00CF
|
||||||
|
00D0 00D1 00D2 00D3 00D4 00D5 00D6 00D7 00D8 00D9 00DA 00DB 00DC 00DD 00DE 00DF
|
||||||
|
00E0 00E1 00E2 00E3 00E4 00E5 00E6 00E7 00E8 00E9 00EA 00EB 00EC 00ED 00EE 00EF
|
||||||
|
00F0 00F1 00F2 00F3 00F4 00F5 00F6 00F7 00F8 00F9 00FA 00FB 00FC 00FD 00FE 00FF
|
||||||
|
</map>
|
||||||
|
</unicode>
|
||||||
|
|
||||||
|
<collation name="latin1_test">
|
||||||
|
<map>
|
||||||
|
00 01 02 03 37 2D 2E 2F 16 05 25 0B 0C 0D 0E 0F
|
||||||
|
10 11 12 13 3C 3D 32 26 18 19 3F 27 1C 1D 1E 1F
|
||||||
|
40 4F 7F 7B 5B 6C 50 7D 4D 5D 5C 4E 6B 60 4B 61
|
||||||
|
F0 F1 F2 F3 F4 F5 F6 F7 F8 F9 7A 5E 4C 7E 6E 6F
|
||||||
|
7C C1 C2 C3 C4 C5 C6 C7 C8 C9 D1 D2 D3 D4 D5 D6
|
||||||
|
D7 D8 D9 E2 E3 E4 E5 E6 E7 E8 E9 4A E0 5A 5F 6D
|
||||||
|
79 81 82 83 84 85 86 87 88 89 91 92 93 94 95 96
|
||||||
|
97 98 99 A2 A3 A4 A5 A6 A7 A8 A9 C0 6A D0 A1 07
|
||||||
|
20 21 22 23 24 15 06 17 28 29 2A 2B 2C 09 0A 1B
|
||||||
|
30 31 1A 33 34 35 36 08 38 39 3A 3B 04 14 3E E1
|
||||||
|
41 42 43 44 45 46 47 48 49 51 52 53 54 55 56 57
|
||||||
|
58 59 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
||||||
|
76 77 78 80 8A 8B 8C 8D 8E 8F 90 9A 9B 9C 9D 9E
|
||||||
|
9F A0 AA AB AC AD AE AF B0 B1 B2 B3 B4 B5 B6 B7
|
||||||
|
B8 B9 BA BB BC BD BE BF CA CB CC CD CE CF DA DB
|
||||||
|
DC DD DE DF EA EB EC ED EE EF FA FB FC FD FE FF
|
||||||
|
</map>
|
||||||
|
</collation>
|
||||||
|
|
||||||
|
</charset>
|
||||||
|
|
||||||
|
</charsets>
|
|
@ -86,3 +86,8 @@ select hex(c1) as h, c1 from t1 order by c1, h;
|
||||||
select group_concat(hex(c1) order by hex(c1)) from t1 group by c1;
|
select group_concat(hex(c1) order by hex(c1)) from t1 group by c1;
|
||||||
select group_concat(c1 order by hex(c1) SEPARATOR '') from t1 group by c1;
|
select group_concat(c1 order by hex(c1) SEPARATOR '') from t1 group by c1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
|
--echo Bug#46448 trailing spaces are not ignored when user collation maps space != 0x20
|
||||||
|
set names latin1;
|
||||||
|
show collation like 'latin1_test';
|
||||||
|
select "foo" = "foo " collate latin1_test;
|
||||||
|
|
|
@ -185,8 +185,8 @@ int my_strnncollsp_simple(CHARSET_INFO * cs, const uchar *a, size_t a_length,
|
||||||
}
|
}
|
||||||
for (end= a + a_length-length; a < end ; a++)
|
for (end= a + a_length-length; a < end ; a++)
|
||||||
{
|
{
|
||||||
if (map[*a] != ' ')
|
if (map[*a] != map[' '])
|
||||||
return (map[*a] < ' ') ? -swap : swap;
|
return (map[*a] < map[' ']) ? -swap : swap;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
|
|
Loading…
Reference in a new issue