Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
d58a6c7c
Commit
d58a6c7c
authored
Dec 12, 2005
by
jan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
trunk: Port a fix for bug #15308 Problem of Order with Enum Column in Primary
Key from branches/5.0.
parent
d95245ce
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
88 additions
and
53 deletions
+88
-53
handler/ha_innodb.cc
handler/ha_innodb.cc
+88
-53
No files found.
handler/ha_innodb.cc
View file @
d58a6c7c
...
...
@@ -2868,8 +2868,6 @@ ha_innobase::store_key_val_for_row(
char
*
buff_start
=
buff
;
enum_field_types
mysql_type
;
Field
*
field
;
ulint
blob_len
;
byte
*
blob_data
;
ibool
is_null
;
DBUG_ENTER
(
"store_key_val_for_row"
);
...
...
@@ -2924,14 +2922,19 @@ ha_innobase::store_key_val_for_row(
ulint
len
;
byte
*
data
;
ulint
key_len
;
ulint
true_len
;
CHARSET_INFO
*
cs
;
int
error
=
0
;
key_len
=
key_part
->
length
;
if
(
is_null
)
{
buff
+=
key_
part
->
length
+
2
;
buff
+=
key_
len
+
2
;
continue
;
}
cs
=
field
->
charset
();
true_len
=
key_len
;
lenlen
=
(
ulint
)
(((
Field_varstring
*
)
field
)
->
length_bytes
);
...
...
@@ -2941,23 +2944,22 @@ ha_innobase::store_key_val_for_row(
+
(
ulint
)
get_field_offset
(
table
,
field
)),
lenlen
);
/* In a column prefix index, we may need to truncate
the stored value: */
cs
=
key_part
->
field
->
charset
();
/* For multi byte character sets we need to calculate
the true length of the key */
if
(
cs
->
mbmaxlen
>
1
&&
key_part
->
length
>
0
)
{
key_len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
if
(
key_len
>
0
&&
cs
->
mbmaxlen
>
1
)
{
true_len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
(
const
char
*
)
data
,
(
const
char
*
)
data
+
key_part
->
length
,
key_part
->
length
/
cs
->
mbmaxlen
,
(
const
char
*
)
data
+
key_len
,
key_len
/
cs
->
mbmaxlen
,
&
error
);
}
else
{
key_len
=
key_part
->
length
;
}
if
(
len
>
key_len
)
{
len
=
key_len
;
/* In a column prefix index, we may need to truncate
the stored value: */
if
(
len
>
true_len
)
{
len
=
true_len
;
}
/* The length in a key value is always stored in 2
...
...
@@ -2974,7 +2976,7 @@ ha_innobase::store_key_val_for_row(
actual data. The rest of the space was reset to zero
in the bzero() call above. */
buff
+=
key_
part
->
length
;
buff
+=
key_
len
;
}
else
if
(
mysql_type
==
FIELD_TYPE_TINY_BLOB
||
mysql_type
==
FIELD_TYPE_MEDIUM_BLOB
...
...
@@ -2984,16 +2986,24 @@ ha_innobase::store_key_val_for_row(
CHARSET_INFO
*
cs
;
ulint
key_len
;
ulint
len
;
ulint
true_len
;
int
error
=
0
;
ulint
blob_len
;
byte
*
blob_data
;
ut_a
(
key_part
->
key_part_flag
&
HA_PART_KEY_SEG
);
key_len
=
key_part
->
length
;
if
(
is_null
)
{
buff
+=
key_
part
->
length
+
2
;
buff
+=
key_
len
+
2
;
continue
;
}
cs
=
field
->
charset
();
true_len
=
key_len
;
blob_data
=
row_mysql_read_blob_ref
(
&
blob_len
,
(
byte
*
)
(
record
+
(
ulint
)
get_field_offset
(
table
,
field
)),
...
...
@@ -3002,25 +3012,24 @@ ha_innobase::store_key_val_for_row(
ut_a
(
get_field_offset
(
table
,
field
)
==
key_part
->
offset
);
/* All indexes on BLOB and TEXT are column prefix
indexes, and we may need to truncate the data to be
stored in the key value: */
cs
=
key_part
->
field
->
charset
();
/* For multi byte character sets we need to calculate
the true length of the key */
if
(
cs
->
mbmaxlen
>
1
&&
key_part
->
length
>
0
)
{
key_len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
if
(
key_len
>
0
&&
cs
->
mbmaxlen
>
1
)
{
true_len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
(
const
char
*
)
blob_data
,
(
const
char
*
)
blob_data
+
key_part
->
length
,
key_part
->
length
/
cs
->
mbmaxlen
,
+
key_len
,
key_len
/
cs
->
mbmaxlen
,
&
error
);
}
else
{
key_len
=
key_part
->
length
;
}
if
(
blob_len
>
key_len
)
{
blob_len
=
key_len
;
/* All indexes on BLOB and TEXT are column prefix
indexes, and we may need to truncate the data to be
stored in the key value: */
if
(
blob_len
>
true_len
)
{
blob_len
=
true_len
;
}
/* MySQL reserves 2 bytes for the length and the
...
...
@@ -3035,7 +3044,7 @@ ha_innobase::store_key_val_for_row(
/* Note that we always reserve the maximum possible
length of the BLOB prefix in the key value. */
buff
+=
key_
part
->
length
;
buff
+=
key_
len
;
}
else
{
/* Here we handle all other data types except the
true VARCHAR, BLOB and TEXT. Note that the column
...
...
@@ -3043,38 +3052,64 @@ ha_innobase::store_key_val_for_row(
index. */
CHARSET_INFO
*
cs
;
ulint
len
;
ulint
true_len
;
ulint
key_len
;
const
mysql_byte
*
src_start
;
int
error
=
0
;
enum_field_types
real_type
;
key_len
=
key_part
->
length
;
if
(
is_null
)
{
buff
+=
key_
part
->
length
;
buff
+=
key_
len
;
continue
;
}
cs
=
key_part
->
field
->
charset
();
src_start
=
record
+
key_part
->
offset
;
real_type
=
field
->
real_type
();
true_len
=
key_len
;
/* Character set for the field is defined only
fields which type is string and real field
type is not enum or set. For these fields check
if character set is multi byte. */
if
(
real_type
!=
FIELD_TYPE_ENUM
&&
real_type
!=
FIELD_TYPE_SET
&&
(
mysql_type
==
MYSQL_TYPE_VAR_STRING
||
mysql_type
==
MYSQL_TYPE_STRING
))
{
cs
=
field
->
charset
();
if
(
key_part
->
length
>
0
&&
cs
->
mbmaxlen
>
1
)
{
len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
(
const
char
*
)
src_start
,
(
const
char
*
)
src_start
+
key_part
->
length
,
key_part
->
length
/
cs
->
mbmaxlen
,
/* For multi byte character sets we need to
calculate the true length of the key */
if
(
key_len
>
0
&&
cs
->
mbmaxlen
>
1
)
{
true_len
=
(
ulint
)
cs
->
cset
->
well_formed_len
(
cs
,
(
const
char
*
)
src_start
,
(
const
char
*
)
src_start
+
key_len
,
key_len
/
cs
->
mbmaxlen
,
&
error
);
}
else
{
len
=
key_part
->
length
;
}
}
memcpy
(
buff
,
src_start
,
len
);
buff
+=
len
;
memcpy
(
buff
,
src_start
,
true_
len
);
buff
+=
true_
len
;
/* Pad the unused space with spaces */
/* Pad the unused space with spaces. Note that no
padding is ever needed for UCS-2 because in MySQL,
all UCS2 characters are 2 bytes, as MySQL does not
support surrogate pairs, which are needed to represent
characters in the range U+10000 to U+10FFFF. */
if
(
len
<
key_part
->
length
)
{
len
=
key_part
->
length
-
len
;
memset
(
buff
,
' '
,
len
);
buff
+=
len
;
if
(
true_len
<
key_len
)
{
ulint
pad_len
=
key_len
-
true_
len
;
memset
(
buff
,
' '
,
pad_
len
);
buff
+=
pad_
len
;
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment