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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
4b594f07
Commit
4b594f07
authored
Dec 04, 2020
by
Varun Gupta
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More Refactoring
parent
6d93260e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
170 additions
and
174 deletions
+170
-174
sql/uniques.cc
sql/uniques.cc
+60
-87
sql/uniques.h
sql/uniques.h
+110
-87
No files found.
sql/uniques.cc
View file @
4b594f07
...
@@ -888,25 +888,6 @@ Variable_size_keys_descriptor::Variable_size_keys_descriptor(uint length)
...
@@ -888,25 +888,6 @@ Variable_size_keys_descriptor::Variable_size_keys_descriptor(uint length)
}
}
Variable_size_composite_key_desc
::
Variable_size_composite_key_desc
(
uint
length
)
:
Variable_size_keys_descriptor
(
length
),
Encode_key
()
{
}
Variable_size_composite_key_desc_for_gconcat
::
Variable_size_composite_key_desc_for_gconcat
(
uint
length
)
:
Variable_size_keys_descriptor
(
length
),
Encode_key_for_group_concat
()
{
}
Variable_size_keys_simple
::
Variable_size_keys_simple
(
uint
length
)
:
Variable_size_keys_descriptor
(
length
),
Encode_key
()
{
}
/*
/*
@brief
@brief
Setup the structures that are used when Unique stores packed values
Setup the structures that are used when Unique stores packed values
...
@@ -930,18 +911,11 @@ Variable_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
...
@@ -930,18 +911,11 @@ Variable_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
uint
non_const_args
,
uint
non_const_args
,
uint
arg_count
)
uint
arg_count
)
{
{
SORT_FIELD
*
sort
,
*
pos
;
SORT_FIELD
*
pos
;
if
(
init
())
if
(
init
(
thd
,
non_const_args
))
return
true
;
return
true
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
pos
=
sortorder
;
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
)
*
non_const_args
);
pos
=
sort
=
sortorder
;
if
(
!
pos
)
return
true
;
sort_keys
=
new
Sort_keys
(
sortorder
,
non_const_args
);
if
(
!
sort_keys
)
return
true
;
sort
=
pos
=
sortorder
;
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
{
{
Item
*
arg
=
item
->
get_arg
(
i
);
Item
*
arg
=
item
->
get_arg
(
i
);
...
@@ -975,20 +949,11 @@ Variable_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
...
@@ -975,20 +949,11 @@ Variable_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
bool
Variable_size_keys_descriptor
::
setup_for_field
(
THD
*
thd
,
Field
*
field
)
bool
Variable_size_keys_descriptor
::
setup_for_field
(
THD
*
thd
,
Field
*
field
)
{
{
SORT_FIELD
*
sort
,
*
pos
;
SORT_FIELD
*
pos
;
if
(
init
())
if
(
init
(
thd
,
1
))
return
true
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
));
pos
=
sort
=
sortorder
;
if
(
!
pos
)
return
true
;
sort_keys
=
new
Sort_keys
(
sortorder
,
1
);
if
(
!
sort_keys
)
return
true
;
return
true
;
sort
=
pos
=
sortorder
;
pos
=
sortorder
;
pos
->
setup_key_part_for_variable_size_key
(
field
);
// Nulls are always excluded
pos
->
setup_key_part_for_variable_size_key
(
field
);
return
false
;
return
false
;
}
}
...
@@ -1067,7 +1032,8 @@ uchar* Variable_size_composite_key_desc::make_record(bool exclude_nulls)
...
@@ -1067,7 +1032,8 @@ uchar* Variable_size_composite_key_desc::make_record(bool exclude_nulls)
return
make_encoded_record
(
sort_keys
,
exclude_nulls
);
return
make_encoded_record
(
sort_keys
,
exclude_nulls
);
}
}
uchar
*
Variable_size_composite_key_desc_for_gconcat
::
make_record
(
bool
exclude_nulls
)
uchar
*
Variable_size_composite_key_desc_for_gconcat
::
make_record
(
bool
exclude_nulls
)
{
{
return
make_encoded_record
(
sort_keys
,
exclude_nulls
);
return
make_encoded_record
(
sort_keys
,
exclude_nulls
);
}
}
...
@@ -1079,21 +1045,51 @@ uchar* Variable_size_keys_simple::make_record(bool exclude_nulls)
...
@@ -1079,21 +1045,51 @@ uchar* Variable_size_keys_simple::make_record(bool exclude_nulls)
}
}
bool
Variable_size_composite_key_desc
::
init
()
/*
@brief
Create the sortorder and Sort keys structures for a descriptor
@param thd THD structure
@param count Number of key parts to be allocated
@retval
TRUE ERROR
FALSE structures successfully created
*/
bool
Descriptor
::
init
(
THD
*
thd
,
uint
count
)
{
if
(
sortorder
)
return
false
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
)
*
count
);
if
(
!
sortorder
)
return
true
;
// OOM
sort_keys
=
new
Sort_keys
(
sortorder
,
count
);
if
(
!
sort_keys
)
return
true
;
// OOM
return
false
;
}
bool
Variable_size_composite_key_desc
::
init
(
THD
*
thd
,
uint
count
)
{
{
return
Encode_key
::
init
(
max_length
);
return
Descriptor
::
init
(
thd
,
count
)
||
Encode_variable_size_key
::
init
(
max_length
);
}
}
bool
Variable_size_composite_key_desc_for_gconcat
::
init
()
bool
Variable_size_composite_key_desc_for_gconcat
::
init
(
THD
*
thd
,
uint
count
)
{
{
return
Encode_key
::
init
(
max_length
);
return
Descriptor
::
init
(
thd
,
count
)
||
Encode_key_for_group_concat
::
init
(
max_length
);
}
}
bool
Variable_size_keys_simple
::
init
()
bool
Variable_size_keys_simple
::
init
(
THD
*
thd
,
uint
count
)
{
{
return
Encode_key
::
init
(
max_length
);
return
Descriptor
::
init
(
thd
,
count
)
||
Encode_variable_size_key
::
init
(
max_length
);
}
}
...
@@ -1103,18 +1099,11 @@ Variable_size_composite_key_desc_for_gconcat::setup_for_item(THD *thd,
...
@@ -1103,18 +1099,11 @@ Variable_size_composite_key_desc_for_gconcat::setup_for_item(THD *thd,
uint
non_const_args
,
uint
non_const_args
,
uint
arg_count
)
uint
arg_count
)
{
{
SORT_FIELD
*
sort
,
*
pos
;
if
(
init
(
thd
,
non_const_args
))
if
(
init
())
return
true
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
)
*
non_const_args
);
pos
=
sort
=
sortorder
;
if
(
!
pos
)
return
true
;
sort_keys
=
new
Sort_keys
(
sortorder
,
non_const_args
);
if
(
!
sort_keys
)
return
true
;
return
true
;
sort
=
pos
=
sortorder
;
SORT_FIELD
*
pos
;
pos
=
sortorder
;
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
{
{
Item
*
arg
=
item
->
get_arg
(
i
);
Item
*
arg
=
item
->
get_arg
(
i
);
...
@@ -1155,18 +1144,11 @@ Fixed_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
...
@@ -1155,18 +1144,11 @@ Fixed_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
uint
non_const_args
,
uint
non_const_args
,
uint
arg_count
)
uint
arg_count
)
{
{
SORT_FIELD
*
sort
,
*
pos
;
SORT_FIELD
*
pos
;
if
(
sortorder
)
if
(
Descriptor
::
init
(
thd
,
non_const_args
))
return
false
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
)
*
non_const_args
);
pos
=
sort
=
sortorder
;
if
(
!
pos
)
return
true
;
return
true
;
sort_keys
=
new
Sort_keys
(
sortorder
,
non_const_args
);
pos
=
sortorder
;
if
(
!
sort_keys
)
return
true
;
sort
=
pos
=
sortorder
;
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
for
(
uint
i
=
0
;
i
<
arg_count
;
i
++
)
{
{
Item
*
arg
=
item
->
get_arg
(
i
);
Item
*
arg
=
item
->
get_arg
(
i
);
...
@@ -1186,19 +1168,10 @@ Fixed_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
...
@@ -1186,19 +1168,10 @@ Fixed_size_keys_descriptor::setup_for_item(THD *thd, Item_sum *item,
bool
bool
Fixed_size_keys_descriptor
::
setup_for_field
(
THD
*
thd
,
Field
*
field
)
Fixed_size_keys_descriptor
::
setup_for_field
(
THD
*
thd
,
Field
*
field
)
{
{
SORT_FIELD
*
sort
,
*
pos
;
SORT_FIELD
*
pos
;
if
(
sortorder
)
if
(
Descriptor
::
init
(
thd
,
1
))
return
false
;
DBUG_ASSERT
(
sort_keys
==
NULL
);
sortorder
=
(
SORT_FIELD
*
)
thd
->
alloc
(
sizeof
(
SORT_FIELD
));
pos
=
sort
=
sortorder
;
if
(
!
pos
)
return
true
;
return
true
;
sort_keys
=
new
Sort_keys
(
sortorder
,
1
);
pos
=
sortorder
;
if
(
!
sort_keys
)
return
true
;
sort
=
pos
=
sortorder
;
pos
->
setup_key_part_for_fixed_size_key
(
field
);
pos
->
setup_key_part_for_fixed_size_key
(
field
);
return
false
;
return
false
;
...
@@ -1312,8 +1285,8 @@ Encode_key::~Encode_key()
...
@@ -1312,8 +1285,8 @@ Encode_key::~Encode_key()
0 NULL value
0 NULL value
>0 length of the packed record
>0 length of the packed record
*/
*/
uchar
*
Encode_key
::
make_encoded_record
(
Sort_keys
*
sort_keys
,
uchar
*
Encode_
variable_size_
key
::
make_encoded_record
(
Sort_keys
*
sort_keys
,
bool
exclude_nulls
)
bool
exclude_nulls
)
{
{
Field
*
field
;
Field
*
field
;
SORT_FIELD
*
sort_field
;
SORT_FIELD
*
sort_field
;
...
@@ -1389,4 +1362,4 @@ Encode_key_for_group_concat::make_encoded_record(Sort_keys *sort_keys,
...
@@ -1389,4 +1362,4 @@ Encode_key_for_group_concat::make_encoded_record(Sort_keys *sort_keys,
length
=
static_cast
<
uint
>
(
to
-
orig_to
);
length
=
static_cast
<
uint
>
(
to
-
orig_to
);
Variable_size_keys_descriptor
::
store_packed_length
(
orig_to
,
length
);
Variable_size_keys_descriptor
::
store_packed_length
(
orig_to
,
length
);
return
rec_ptr
;
return
rec_ptr
;
}
}
\ No newline at end of file
sql/uniques.h
View file @
4b594f07
...
@@ -18,6 +18,54 @@
...
@@ -18,6 +18,54 @@
#include "filesort.h"
#include "filesort.h"
/*
Encode a key into a particular format. The format depends whether
the key is of fixed size or variable size.
@notes
Currently this encoding is only done for variable size keys
*/
class
Encode_key
{
protected:
/*
Packed record ptr for a record of the table, the packed value in this
record is added to the unique tree
*/
uchar
*
rec_ptr
;
String
tmp_buffer
;
public:
virtual
~
Encode_key
();
virtual
uchar
*
make_encoded_record
(
Sort_keys
*
keys
,
bool
exclude_nulls
)
=
0
;
bool
init
(
uint
length
);
uchar
*
get_rec_ptr
()
{
return
rec_ptr
;
}
};
class
Encode_variable_size_key
:
public
Encode_key
{
public:
Encode_variable_size_key
()
{
rec_ptr
=
NULL
;
}
virtual
~
Encode_variable_size_key
()
{}
uchar
*
make_encoded_record
(
Sort_keys
*
keys
,
bool
exclude_nulls
)
override
;
};
class
Encode_key_for_group_concat
:
public
Encode_variable_size_key
{
public:
Encode_key_for_group_concat
()
:
Encode_variable_size_key
(){}
~
Encode_key_for_group_concat
()
{}
uchar
*
make_encoded_record
(
Sort_keys
*
keys
,
bool
exclude_nulls
)
override
;
};
/*
/*
Descriptor class storing information about the keys that would be
Descriptor class storing information about the keys that would be
...
@@ -25,6 +73,7 @@
...
@@ -25,6 +73,7 @@
extended by other class to support descriptors for keys with fixed and
extended by other class to support descriptors for keys with fixed and
variable size.
variable size.
*/
*/
class
Descriptor
:
public
Sql_alloc
class
Descriptor
:
public
Sql_alloc
{
{
protected:
protected:
...
@@ -76,41 +125,7 @@ class Descriptor : public Sql_alloc
...
@@ -76,41 +125,7 @@ class Descriptor : public Sql_alloc
virtual
uchar
*
make_record
(
bool
exclude_nulls
)
{
return
NULL
;
}
virtual
uchar
*
make_record
(
bool
exclude_nulls
)
{
return
NULL
;
}
virtual
bool
is_single_arg
()
=
0
;
virtual
bool
is_single_arg
()
=
0
;
};
virtual
bool
init
(
THD
*
thd
,
uint
count
);
/*
Class to encode a key into a particular format. The format depends whether
the key is of fixed size or variable size.
@note
Currently this encoding is only done for variable size keys
*/
class
Encode_key
{
protected:
/*
Packed record ptr for a record of the table, the packed value in this
record is added to the unique tree
*/
uchar
*
rec_ptr
;
String
tmp_buffer
;
public:
Encode_key
()
:
rec_ptr
(
NULL
)
{}
virtual
~
Encode_key
();
virtual
uchar
*
make_encoded_record
(
Sort_keys
*
keys
,
bool
exclude_nulls
);
bool
init
(
uint
length
);
uchar
*
get_rec_ptr
()
{
return
rec_ptr
;
}
};
class
Encode_key_for_group_concat
:
public
Encode_key
{
public:
Encode_key_for_group_concat
()
:
Encode_key
()
{}
~
Encode_key_for_group_concat
()
{}
uchar
*
make_encoded_record
(
Sort_keys
*
keys
,
bool
exclude_nulls
)
override
;
};
};
...
@@ -165,7 +180,7 @@ class Fixed_size_keys_for_rowids: public Fixed_size_keys_descriptor
...
@@ -165,7 +180,7 @@ class Fixed_size_keys_for_rowids: public Fixed_size_keys_descriptor
/*
/*
Descriptor for fixed size keys where a keypart can be NULL
Descriptor for fixed size keys where a key
part can be NULL
Used currently in JSON_ARRAYAGG
Used currently in JSON_ARRAYAGG
*/
*/
...
@@ -221,7 +236,6 @@ class Variable_size_keys_descriptor : public Descriptor
...
@@ -221,7 +236,6 @@ class Variable_size_keys_descriptor : public Descriptor
return
read_packed_length
(
ptr
);
return
read_packed_length
(
ptr
);
}
}
virtual
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
{
return
0
;
}
virtual
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
{
return
0
;
}
virtual
bool
init
()
{
return
false
;
}
virtual
bool
is_single_arg
()
override
{
return
false
;
}
virtual
bool
is_single_arg
()
override
{
return
false
;
}
virtual
bool
setup_for_item
(
THD
*
thd
,
Item_sum
*
item
,
virtual
bool
setup_for_item
(
THD
*
thd
,
Item_sum
*
item
,
...
@@ -245,21 +259,23 @@ class Variable_size_keys_descriptor : public Descriptor
...
@@ -245,21 +259,23 @@ class Variable_size_keys_descriptor : public Descriptor
/*
/*
Descriptor for variable size keys with only one component
Descriptor for variable size keys with only one component
Used by EITS, JSON_ARRAYAGG,
Used by EITS, JSON_ARRAYAGG.
COUNT(DISTINCT col1) AND GROUP_CONCAT(DISTINCT col1) => only one item is allowed
COUNT(DISTINCT col) AND GROUP_CONCAT(DISTINCT col) are also allowed
that the number of arguments with DISTINCT is 1.
*/
*/
class
Variable_size_keys_simple
:
public
Variable_size_keys_descriptor
,
class
Variable_size_keys_simple
:
public
Variable_size_keys_descriptor
,
public
Encode_key
public
Encode_
variable_size_
key
{
{
public:
public:
Variable_size_keys_simple
(
uint
length
);
Variable_size_keys_simple
(
uint
length
)
virtual
~
Variable_size_keys_simple
()
{}
:
Variable_size_keys_descriptor
(
length
),
Encode_variable_size_key
()
{}
~
Variable_size_keys_simple
()
{}
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
uchar
*
get_rec_ptr
()
{
return
rec_ptr
;
}
uchar
*
get_rec_ptr
()
{
return
rec_ptr
;
}
bool
init
()
override
;
bool
is_single_arg
()
override
{
return
true
;
}
bool
is_single_arg
()
override
{
return
true
;
}
bool
init
(
THD
*
thd
,
uint
count
)
override
;
};
};
...
@@ -267,14 +283,15 @@ class Variable_size_keys_simple : public Variable_size_keys_descriptor,
...
@@ -267,14 +283,15 @@ class Variable_size_keys_simple : public Variable_size_keys_descriptor,
Descriptor for variable sized keys with multiple key parts
Descriptor for variable sized keys with multiple key parts
*/
*/
class
Variable_size_composite_key_desc
:
public
Variable_size_keys_descriptor
,
class
Variable_size_composite_key_desc
:
public
Variable_size_keys_descriptor
,
public
Encode_key
public
Encode_
variable_size_
key
{
{
public:
public:
Variable_size_composite_key_desc
(
uint
length
);
Variable_size_composite_key_desc
(
uint
length
)
virtual
~
Variable_size_composite_key_desc
()
{}
:
Variable_size_keys_descriptor
(
length
),
Encode_variable_size_key
()
{}
~
Variable_size_composite_key_desc
()
{}
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
bool
init
()
override
;
bool
init
(
THD
*
thd
,
uint
count
)
override
;
};
};
...
@@ -284,16 +301,18 @@ class Variable_size_composite_key_desc : public Variable_size_keys_descriptor,
...
@@ -284,16 +301,18 @@ class Variable_size_composite_key_desc : public Variable_size_keys_descriptor,
*/
*/
class
Variable_size_composite_key_desc_for_gconcat
:
class
Variable_size_composite_key_desc_for_gconcat
:
public
Variable_size_keys_descriptor
,
public
Encode_key_for_group_concat
public
Variable_size_keys_descriptor
,
public
Encode_key_for_group_concat
{
{
public:
public:
Variable_size_composite_key_desc_for_gconcat
(
uint
length
);
Variable_size_composite_key_desc_for_gconcat
(
uint
length
)
virtual
~
Variable_size_composite_key_desc_for_gconcat
()
{}
:
Variable_size_keys_descriptor
(
length
),
Encode_key_for_group_concat
()
{}
~
Variable_size_composite_key_desc_for_gconcat
()
{}
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
int
compare_keys
(
uchar
*
a
,
uchar
*
b
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
uchar
*
make_record
(
bool
exclude_nulls
)
override
;
bool
init
()
override
;
bool
setup_for_item
(
THD
*
thd
,
Item_sum
*
item
,
bool
setup_for_item
(
THD
*
thd
,
Item_sum
*
item
,
uint
non_const_args
,
uint
arg_count
)
override
;
uint
non_const_args
,
uint
arg_count
)
override
;
bool
init
(
THD
*
thd
,
uint
count
)
override
;
};
};
...
@@ -306,7 +325,7 @@ class Unique : public Sql_alloc {
...
@@ -306,7 +325,7 @@ class Unique : public Sql_alloc {
protected:
protected:
/*
/*
Storing all
relevant
information of the expressions whose value are
Storing all
meta-data
information of the expressions whose value are
being added to the Unique tree
being added to the Unique tree
*/
*/
Descriptor
*
m_descriptor
;
Descriptor
*
m_descriptor
;
...
@@ -328,11 +347,11 @@ class Unique : public Sql_alloc {
...
@@ -328,11 +347,11 @@ class Unique : public Sql_alloc {
virtual
size_t
get_max_in_memory_size
()
const
=
0
;
virtual
size_t
get_max_in_memory_size
()
const
=
0
;
virtual
bool
is_in_memory
()
=
0
;
virtual
bool
is_in_memory
()
=
0
;
// This will be renamed:
virtual
ulong
elements_in_tree
()
=
0
;
virtual
ulong
elements_in_tree
()
=
0
;
Descriptor
*
get_descriptor
()
{
return
m_descriptor
;
}
Descriptor
*
get_descriptor
()
{
return
m_descriptor
;
}
};
};
/*
/*
Unique_impl -- class for unique (removing of duplicates).
Unique_impl -- class for unique (removing of duplicates).
Puts all values to the TREE. If the tree becomes too big,
Puts all values to the TREE. If the tree becomes too big,
...
@@ -355,13 +374,12 @@ class Unique_impl : public Unique {
...
@@ -355,13 +374,12 @@ class Unique_impl : public Unique {
uint
full_size
;
/* Size of element + space needed to store the number of
uint
full_size
;
/* Size of element + space needed to store the number of
duplicates found for the element. */
duplicates found for the element. */
uint
min_dupl_count
;
/* Minimum number of occurences of element required for
uint
min_dupl_count
;
/* Minimum number of occur
r
ences of element required for
it to be written to record_pointers.
it to be written to record_pointers.
always 0 for unions, > 0 for intersections */
always 0 for unions, > 0 for intersections */
bool
with_counters
;
bool
with_counters
;
/*
size in bytes used for storing keys in the Unique tree
// size in bytes used for storing keys in the Unique tree
*/
size_t
memory_used
;
size_t
memory_used
;
ulong
elements
;
ulong
elements
;
SORT_INFO
sort
;
SORT_INFO
sort
;
...
@@ -384,40 +402,15 @@ class Unique_impl : public Unique {
...
@@ -384,40 +402,15 @@ class Unique_impl : public Unique {
return
record_size
>
space_left
();
return
record_size
>
space_left
();
}
}
public:
/*
@brief
Returns the number of elements in the unique instance
@details
If all the elements fit in the memeory, then this returns all the
distinct elements.
*/
ulong
get_n_elements
()
override
{
return
is_in_memory
()
?
elements_in_tree
()
:
elements
;
}
SORT_INFO
*
get_sort
()
override
{
return
&
sort
;
}
Unique_impl
(
qsort_cmp2
comp_func
,
void
*
comp_func_fixed_arg
,
uint
size_arg
,
size_t
max_in_memory_size_arg
,
uint
min_dupl_count_arg
,
Descriptor
*
desc
);
virtual
~
Unique_impl
();
ulong
elements_in_tree
()
{
return
tree
.
elements_in_tree
;
}
bool
unique_add
(
void
*
ptr
)
override
{
return
unique_add
(
ptr
,
m_descriptor
->
get_length_of_key
((
uchar
*
)
ptr
));
}
/*
/*
@brief
@brief
Add a record to the Unique tree
Add a record to the Unique tree
@param
@param
ptr key value
ptr key value
size length of the key
size length of the key
@retval
TRUE ERROE
FALSE key successfully inserted in the Unique tree
*/
*/
bool
unique_add
(
void
*
ptr
,
uint
size_arg
)
bool
unique_add
(
void
*
ptr
,
uint
size_arg
)
...
@@ -442,6 +435,34 @@ class Unique_impl : public Unique {
...
@@ -442,6 +435,34 @@ class Unique_impl : public Unique {
DBUG_RETURN
(
!
res
);
DBUG_RETURN
(
!
res
);
}
}
public:
/*
@brief
Returns the number of elements in the unique instance
@details
If all the elements fit in the memory, then this returns all the
distinct elements.
*/
ulong
get_n_elements
()
override
{
return
is_in_memory
()
?
elements_in_tree
()
:
elements
;
}
SORT_INFO
*
get_sort
()
override
{
return
&
sort
;
}
Unique_impl
(
qsort_cmp2
comp_func
,
void
*
comp_func_fixed_arg
,
uint
size_arg
,
size_t
max_in_memory_size_arg
,
uint
min_dupl_count_arg
,
Descriptor
*
desc
);
~
Unique_impl
();
ulong
elements_in_tree
()
{
return
tree
.
elements_in_tree
;
}
bool
unique_add
(
void
*
ptr
)
override
{
return
unique_add
(
ptr
,
m_descriptor
->
get_length_of_key
((
uchar
*
)
ptr
));
}
bool
is_in_memory
()
{
return
(
my_b_tell
(
&
file
)
==
0
);
}
bool
is_in_memory
()
{
return
(
my_b_tell
(
&
file
)
==
0
);
}
void
close_for_expansion
()
{
tree
.
flag
=
TREE_ONLY_DUPS
;
}
void
close_for_expansion
()
{
tree
.
flag
=
TREE_ONLY_DUPS
;
}
...
@@ -476,10 +497,12 @@ class Unique_impl : public Unique {
...
@@ -476,10 +497,12 @@ class Unique_impl : public Unique {
size_t
get_max_in_memory_size
()
const
{
return
max_in_memory_size
;
}
size_t
get_max_in_memory_size
()
const
{
return
max_in_memory_size
;
}
bool
is_count_stored
()
{
return
with_counters
;
}
bool
is_count_stored
()
{
return
with_counters
;
}
IO_CACHE
*
get_file
()
{
return
&
file
;
}
IO_CACHE
*
get_file
()
{
return
&
file
;
}
virtual
int
write_record_to_file
(
uchar
*
key
);
int
write_record_to_file
(
uchar
*
key
);
// returns TRUE if the unique tree stores packed values
// returns TRUE if the unique tree stores packed values
bool
is_variable_sized
()
{
return
m_descriptor
->
is_variable_sized
();
}
bool
is_variable_sized
()
{
return
m_descriptor
->
is_variable_sized
();
}
// returns TRUE if the key to be inserted has only one component
bool
is_single_arg
()
{
return
m_descriptor
->
is_single_arg
();
}
bool
is_single_arg
()
{
return
m_descriptor
->
is_single_arg
();
}
Descriptor
*
get_descriptor
()
{
return
m_descriptor
;
}
Descriptor
*
get_descriptor
()
{
return
m_descriptor
;
}
...
@@ -489,7 +512,7 @@ class Unique_impl : public Unique {
...
@@ -489,7 +512,7 @@ class Unique_impl : public Unique {
friend
int
unique_write_to_file_with_count
(
uchar
*
key
,
element_count
count
,
friend
int
unique_write_to_file_with_count
(
uchar
*
key
,
element_count
count
,
Unique_impl
*
unique
);
Unique_impl
*
unique
);
friend
int
unique_intersect_write_to_ptrs
(
uchar
*
key
,
element_count
count
,
friend
int
unique_intersect_write_to_ptrs
(
uchar
*
key
,
element_count
count
,
Unique_impl
*
unique
);
Unique_impl
*
unique
);
};
};
#endif
/* UNIQUE_INCLUDED */
#endif
/* UNIQUE_INCLUDED */
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