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
5d364e53
Commit
5d364e53
authored
Apr 09, 2013
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
handlerton::discover_table_names() can not discover only
"unknown" tables. Duplicates are possible - deal with them.
parent
a489ae89
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
191 additions
and
125 deletions
+191
-125
sql/discover.cc
sql/discover.cc
+2
-3
sql/discover.h
sql/discover.h
+1
-1
sql/handler.cc
sql/handler.cc
+145
-39
sql/handler.h
sql/handler.h
+21
-4
sql/item_subselect.cc
sql/item_subselect.cc
+1
-1
sql/sql_array.h
sql/sql_array.h
+7
-2
sql/sql_show.cc
sql/sql_show.cc
+10
-71
storage/sphinx/ha_sphinx.cc
storage/sphinx/ha_sphinx.cc
+4
-4
No files found.
sql/discover.cc
View file @
5d364e53
...
@@ -232,11 +232,10 @@ int extension_based_table_discovery(MY_DIR *dirp, const char *ext_meta,
...
@@ -232,11 +232,10 @@ int extension_based_table_discovery(MY_DIR *dirp, const char *ext_meta,
will ignore them. Anyone still having these files, should disable
will ignore them. Anyone still having these files, should disable
discovering engines, and rename these invalid table files.
discovering engines, and rename these invalid table files.
*/
*/
int
ext_table_discovery_simple
(
MY_DIR
*
dirp
,
const
char
*
ext_meta
,
int
ext_table_discovery_simple
(
MY_DIR
*
dirp
,
handlerton
::
discovered_list
*
result
)
handlerton
::
discovered_list
*
result
)
{
{
CHARSET_INFO
*
cs
=
character_set_filesystem
;
CHARSET_INFO
*
cs
=
character_set_filesystem
;
size_t
ext_meta_len
=
strlen
(
ext_meta
);
FILEINFO
*
cur
,
*
end
;
FILEINFO
*
cur
,
*
end
;
cur
=
dirp
->
dir_entry
;
cur
=
dirp
->
dir_entry
;
...
@@ -248,7 +247,7 @@ int ext_table_discovery_simple(MY_DIR *dirp, const char *ext_meta,
...
@@ -248,7 +247,7 @@ int ext_table_discovery_simple(MY_DIR *dirp, const char *ext_meta,
if
(
ext
&&
!
is_prefix
(
cur
->
name
,
tmp_file_prefix
))
if
(
ext
&&
!
is_prefix
(
cur
->
name
,
tmp_file_prefix
))
{
{
if
(
my_strnncoll
(
cs
,
(
uchar
*
)
ext
,
strlen
(
ext
),
if
(
my_strnncoll
(
cs
,
(
uchar
*
)
ext
,
strlen
(
ext
),
(
uchar
*
)
ext_meta
,
ext_meta_len
)
==
0
)
(
uchar
*
)
reg_ext
,
reg_ext_length
)
==
0
)
{
{
*
ext
=
0
;
*
ext
=
0
;
if
(
result
->
add_file
(
cur
->
name
))
if
(
result
->
add_file
(
cur
->
name
))
...
...
sql/discover.h
View file @
5d364e53
...
@@ -25,7 +25,7 @@ int extension_based_table_discovery(MY_DIR *dirp, const char *ext,
...
@@ -25,7 +25,7 @@ int extension_based_table_discovery(MY_DIR *dirp, const char *ext,
handlerton
::
discovered_list
*
tl
);
handlerton
::
discovered_list
*
tl
);
#ifdef MYSQL_SERVER
#ifdef MYSQL_SERVER
int
ext_table_discovery_simple
(
MY_DIR
*
dirp
,
const
char
*
ext_meta
,
int
ext_table_discovery_simple
(
MY_DIR
*
dirp
,
handlerton
::
discovered_list
*
result
);
handlerton
::
discovered_list
*
result
);
#endif
#endif
...
...
sql/handler.cc
View file @
5d364e53
...
@@ -383,12 +383,36 @@ static int ha_finish_errors(void)
...
@@ -383,12 +383,36 @@ static int ha_finish_errors(void)
return
0
;
return
0
;
}
}
volatile
int32
need_full_discover_for_existence
=
0
;
static
volatile
int32
need_full_discover_for_existence
=
0
;
static
volatile
int32
engines_with_discover_table_names
=
0
;
static
int
full_discover_for_existence
(
handlerton
*
,
const
char
*
,
const
char
*
)
static
int
full_discover_for_existence
(
handlerton
*
,
const
char
*
,
const
char
*
)
{
return
1
;
}
{
return
1
;
}
static
int
ext_based_existence
(
handlerton
*
,
const
char
*
,
const
char
*
)
static
int
ext_based_existence
(
handlerton
*
,
const
char
*
,
const
char
*
)
{
return
1
;
}
{
return
1
;
}
static
int
hton_ext_based_table_discovery
(
handlerton
*
hton
,
LEX_STRING
*
db
,
MY_DIR
*
dir
,
handlerton
::
discovered_list
*
result
)
{
/*
tablefile_extensions[0] is the metadata file, see
the comment above tablefile_extensions declaration
*/
return
extension_based_table_discovery
(
dir
,
hton
->
tablefile_extensions
[
0
],
result
);
}
static
void
update_discovery_counters
(
handlerton
*
hton
,
int
val
)
{
if
(
hton
->
discover_table_existence
==
full_discover_for_existence
)
my_atomic_add32
(
&
need_full_discover_for_existence
,
val
);
if
(
hton
->
discover_table_names
)
my_atomic_add32
(
&
engines_with_discover_table_names
,
val
);
}
int
ha_finalize_handlerton
(
st_plugin_int
*
plugin
)
int
ha_finalize_handlerton
(
st_plugin_int
*
plugin
)
{
{
handlerton
*
hton
=
(
handlerton
*
)
plugin
->
data
;
handlerton
*
hton
=
(
handlerton
*
)
plugin
->
data
;
...
@@ -438,11 +462,7 @@ int ha_finalize_handlerton(st_plugin_int *plugin)
...
@@ -438,11 +462,7 @@ int ha_finalize_handlerton(st_plugin_int *plugin)
hton2plugin
[
hton
->
slot
]
=
NULL
;
hton2plugin
[
hton
->
slot
]
=
NULL
;
}
}
if
(
hton
->
discover_table_existence
==
full_discover_for_existence
)
update_discovery_counters
(
hton
,
-
1
);
my_atomic_add32
(
&
need_full_discover_for_existence
,
-
1
);
if
(
hton
->
discover_table_names
)
my_atomic_add32
(
&
engines_with_discover_table_names
,
-
1
);
my_free
(
hton
);
my_free
(
hton
);
...
@@ -451,13 +471,6 @@ int ha_finalize_handlerton(st_plugin_int *plugin)
...
@@ -451,13 +471,6 @@ int ha_finalize_handlerton(st_plugin_int *plugin)
}
}
static
int
hton_ext_based_table_discovery
(
handlerton
*
hton
,
LEX_STRING
*
db
,
MY_DIR
*
dir
,
handlerton
::
discovered_list
*
result
)
{
return
extension_based_table_discovery
(
dir
,
hton
->
tablefile_extensions
[
0
],
result
);
}
int
ha_initialize_handlerton
(
st_plugin_int
*
plugin
)
int
ha_initialize_handlerton
(
st_plugin_int
*
plugin
)
{
{
handlerton
*
hton
;
handlerton
*
hton
;
...
@@ -474,6 +487,9 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
...
@@ -474,6 +487,9 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
goto
err_no_hton_memory
;
goto
err_no_hton_memory
;
}
}
hton
->
tablefile_extensions
=
no_exts
;
hton
->
discover_table_names
=
hton_ext_based_table_discovery
;
hton
->
slot
=
HA_SLOT_UNDEF
;
hton
->
slot
=
HA_SLOT_UNDEF
;
/* Historical Requirement */
/* Historical Requirement */
plugin
->
data
=
hton
;
// shortcut for the future
plugin
->
data
=
hton
;
// shortcut for the future
...
@@ -484,15 +500,11 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
...
@@ -484,15 +500,11 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
goto
err
;
goto
err
;
}
}
// default list file extensions: empty
// hton_ext_based_table_discovery() works only when discovery
if
(
!
hton
->
tablefile_extensions
)
// is supported and the engine if file-based.
hton
->
tablefile_extensions
=
no_exts
;
if
(
hton
->
discover_table_names
==
hton_ext_based_table_discovery
&&
(
!
hton
->
discover_table
||
!
hton
->
tablefile_extensions
[
0
]))
// if the enfine can discover a single table and it is file-based
hton
->
discover_table_names
=
NULL
;
// then it can use a default file-based table names discovery
if
(
!
hton
->
discover_table_names
&&
hton
->
discover_table
&&
hton
->
tablefile_extensions
[
0
])
hton
->
discover_table_names
=
hton_ext_based_table_discovery
;
// default discover_table_existence implementation
// default discover_table_existence implementation
if
(
!
hton
->
discover_table_existence
&&
hton
->
discover_table
)
if
(
!
hton
->
discover_table_existence
&&
hton
->
discover_table
)
...
@@ -500,10 +512,7 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
...
@@ -500,10 +512,7 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
if
(
hton
->
tablefile_extensions
[
0
])
if
(
hton
->
tablefile_extensions
[
0
])
hton
->
discover_table_existence
=
ext_based_existence
;
hton
->
discover_table_existence
=
ext_based_existence
;
else
else
{
hton
->
discover_table_existence
=
full_discover_for_existence
;
hton
->
discover_table_existence
=
full_discover_for_existence
;
my_atomic_add32
(
&
need_full_discover_for_existence
,
1
);
}
}
}
/*
/*
...
@@ -595,8 +604,7 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
...
@@ -595,8 +604,7 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
break
;
break
;
};
};
if
(
hton
->
discover_table_names
)
update_discovery_counters
(
hton
,
1
);
my_atomic_add32
(
&
engines_with_discover_table_names
,
1
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -4474,13 +4482,88 @@ bool ha_table_exists(THD *thd, const char *db, const char *table_name,
...
@@ -4474,13 +4482,88 @@ bool ha_table_exists(THD *thd, const char *db, const char *table_name,
/**
/**
Discover all table names in a given database
Discover all table names in a given database
*/
*/
volatile
int32
engines_with_discover_table_names
=
0
;
extern
"C"
{
static
int
cmp_file_names
(
const
void
*
a
,
const
void
*
b
)
{
CHARSET_INFO
*
cs
=
character_set_filesystem
;
char
*
aa
=
((
FILEINFO
*
)
a
)
->
name
;
char
*
bb
=
((
FILEINFO
*
)
b
)
->
name
;
return
my_strnncoll
(
cs
,
(
uchar
*
)
aa
,
strlen
(
aa
),
(
uchar
*
)
bb
,
strlen
(
bb
));
}
static
int
cmp_table_names
(
LEX_STRING
*
const
*
a
,
LEX_STRING
*
const
*
b
)
{
return
my_strnncoll
(
&
my_charset_bin
,
(
uchar
*
)((
*
a
)
->
str
),
(
*
a
)
->
length
,
(
uchar
*
)((
*
b
)
->
str
),
(
*
b
)
->
length
);
}
}
Discovered_table_list
::
Discovered_table_list
(
THD
*
thd_arg
,
Dynamic_array
<
LEX_STRING
*>
*
tables_arg
,
const
LEX_STRING
*
wild_arg
)
{
thd
=
thd_arg
;
tables
=
tables_arg
;
if
(
wild_arg
->
str
&&
wild_arg
->
str
[
0
])
{
wild
=
wild_arg
->
str
;
wend
=
wild
+
wild_arg
->
length
;
}
else
wild
=
0
;
}
bool
Discovered_table_list
::
add_table
(
const
char
*
tname
,
size_t
tlen
)
{
if
(
wild
&&
my_wildcmp
(
files_charset_info
,
tname
,
tname
+
tlen
,
wild
,
wend
,
wild_prefix
,
wild_one
,
wild_many
))
return
0
;
LEX_STRING
*
name
=
thd
->
make_lex_string
(
tname
,
tlen
);
if
(
!
name
||
tables
->
append
(
name
))
return
1
;
return
0
;
}
bool
Discovered_table_list
::
add_file
(
const
char
*
fname
)
{
char
tname
[
SAFE_NAME_LEN
+
1
];
size_t
tlen
=
filename_to_tablename
(
fname
,
tname
,
sizeof
(
tname
));
return
add_table
(
tname
,
tlen
);
}
void
Discovered_table_list
::
sort
()
{
tables
->
sort
(
cmp_table_names
);
}
void
Discovered_table_list
::
remove_duplicates
()
{
LEX_STRING
**
src
=
tables
->
front
();
LEX_STRING
**
dst
=
src
;
while
(
++
dst
<
tables
->
back
())
{
LEX_STRING
*
s
=
*
src
,
*
d
=
*
dst
;
DBUG_ASSERT
(
strncmp
(
s
->
str
,
d
->
str
,
min
(
s
->
length
,
d
->
length
))
<=
0
);
if
((
s
->
length
!=
d
->
length
||
strncmp
(
s
->
str
,
d
->
str
,
d
->
length
)))
{
src
++
;
if
(
src
!=
dst
)
*
src
=
*
dst
;
}
}
tables
->
set_elements
(
src
-
tables
->
front
()
+
1
);
}
struct
st_discover_names_args
struct
st_discover_names_args
{
{
LEX_STRING
*
db
;
LEX_STRING
*
db
;
MY_DIR
*
dirp
;
MY_DIR
*
dirp
;
handlerton
::
discovered_list
*
result
;
Discovered_table_list
*
result
;
uint
possible_duplicates
;
};
};
static
my_bool
discover_names
(
THD
*
thd
,
plugin_ref
plugin
,
static
my_bool
discover_names
(
THD
*
thd
,
plugin_ref
plugin
,
...
@@ -4488,28 +4571,51 @@ static my_bool discover_names(THD *thd, plugin_ref plugin,
...
@@ -4488,28 +4571,51 @@ static my_bool discover_names(THD *thd, plugin_ref plugin,
{
{
st_discover_names_args
*
args
=
(
st_discover_names_args
*
)
arg
;
st_discover_names_args
*
args
=
(
st_discover_names_args
*
)
arg
;
handlerton
*
ht
=
plugin_data
(
plugin
,
handlerton
*
);
handlerton
*
ht
=
plugin_data
(
plugin
,
handlerton
*
);
if
(
ht
->
state
==
SHOW_OPTION_YES
&&
ht
->
discover_table_names
&&
ht
->
discover_table_names
(
ht
,
args
->
db
,
args
->
dirp
,
args
->
result
))
if
(
ht
->
state
==
SHOW_OPTION_YES
&&
ht
->
discover_table_names
)
return
1
;
{
uint
old_elements
=
args
->
result
->
tables
->
elements
();
if
(
ht
->
discover_table_names
(
ht
,
args
->
db
,
args
->
dirp
,
args
->
result
))
return
1
;
/*
hton_ext_based_table_discovery never discovers a table that has
a corresponding .frm file; but custom engine discover methods might
*/
if
(
ht
->
discover_table_names
!=
hton_ext_based_table_discovery
)
args
->
possible_duplicates
+=
args
->
result
->
tables
->
elements
()
-
old_elements
;
}
return
0
;
return
0
;
}
}
int
ha_discover_table_names
(
THD
*
thd
,
LEX_STRING
*
db
,
MY_DIR
*
dirp
,
int
ha_discover_table_names
(
THD
*
thd
,
LEX_STRING
*
db
,
MY_DIR
*
dirp
,
handlerton
::
discovered
_list
*
result
)
Discovered_table
_list
*
result
)
{
{
int
error
;
int
error
;
DBUG_ENTER
(
"ha_discover_table_names"
);
DBUG_ENTER
(
"ha_discover_table_names"
);
st_discover_names_args
args
=
{
db
,
dirp
,
result
};
if
(
engines_with_discover_table_names
==
0
)
if
(
engines_with_discover_table_names
==
0
)
DBUG_RETURN
(
ext_table_discovery_simple
(
dirp
,
reg_ext
,
result
));
{
error
=
ext_table_discovery_simple
(
dirp
,
result
);
result
->
sort
();
}
else
{
st_discover_names_args
args
=
{
db
,
dirp
,
result
,
0
};
error
=
extension_based_table_discovery
(
dirp
,
reg_ext
,
result
);
/* extension_based_table_discovery relies on dirp being sorted */
my_qsort
(
dirp
->
dir_entry
,
dirp
->
number_of_files
,
sizeof
(
FILEINFO
),
cmp_file_names
);
if
(
!
error
)
error
=
extension_based_table_discovery
(
dirp
,
reg_ext
,
result
)
||
error
=
plugin_foreach
(
thd
,
discover_names
,
MYSQL_STORAGE_ENGINE_PLUGIN
,
plugin_foreach
(
thd
,
discover_names
,
&
args
);
MYSQL_STORAGE_ENGINE_PLUGIN
,
&
args
);
result
->
sort
();
if
(
args
.
possible_duplicates
>
0
)
result
->
remove_duplicates
();
}
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
}
}
...
...
sql/handler.h
View file @
5d364e53
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
#include "thr_lock.h"
/* thr_lock_type, THR_LOCK_DATA */
#include "thr_lock.h"
/* thr_lock_type, THR_LOCK_DATA */
#include "sql_cache.h"
#include "sql_cache.h"
#include "structs.h"
/* SHOW_COMP_OPTION */
#include "structs.h"
/* SHOW_COMP_OPTION */
#include "sql_array.h"
/* Dynamic_array<> */
#include <my_compare.h>
#include <my_compare.h>
#include <ft_global.h>
#include <ft_global.h>
...
@@ -3101,14 +3102,30 @@ int ha_delete_table(THD *thd, handlerton *db_type, const char *path,
...
@@ -3101,14 +3102,30 @@ int ha_delete_table(THD *thd, handlerton *db_type, const char *path,
bool
ha_show_status
(
THD
*
thd
,
handlerton
*
db_type
,
enum
ha_stat_type
stat
);
bool
ha_show_status
(
THD
*
thd
,
handlerton
*
db_type
,
enum
ha_stat_type
stat
);
/* discovery */
/* discovery */
#ifdef MYSQL_SERVER
class
Discovered_table_list
:
public
handlerton
::
discovered_list
{
THD
*
thd
;
const
char
*
wild
,
*
wend
;
public:
Dynamic_array
<
LEX_STRING
*>
*
tables
;
Discovered_table_list
(
THD
*
thd_arg
,
Dynamic_array
<
LEX_STRING
*>
*
tables_arg
,
const
LEX_STRING
*
wild_arg
);
~
Discovered_table_list
()
{}
bool
add_table
(
const
char
*
tname
,
size_t
tlen
);
bool
add_file
(
const
char
*
fname
);
void
sort
();
void
remove_duplicates
();
// assumes that the list is sorted
};
int
ha_discover_table
(
THD
*
thd
,
TABLE_SHARE
*
share
);
int
ha_discover_table
(
THD
*
thd
,
TABLE_SHARE
*
share
);
int
ha_discover_table_names
(
THD
*
thd
,
LEX_STRING
*
db
,
MY_DIR
*
dirp
,
int
ha_discover_table_names
(
THD
*
thd
,
LEX_STRING
*
db
,
MY_DIR
*
dirp
,
handlerton
::
discovered
_list
*
result
);
Discovered_table
_list
*
result
);
bool
ha_table_exists
(
THD
*
thd
,
const
char
*
db
,
const
char
*
table_name
,
bool
ha_table_exists
(
THD
*
thd
,
const
char
*
db
,
const
char
*
table_name
,
handlerton
**
hton
=
0
);
handlerton
**
hton
=
0
);
#ifdef MYSQL_SERVER
extern
volatile
int32
engines_with_discover_table_names
;
#endif
#endif
/* key cache */
/* key cache */
...
...
sql/item_subselect.cc
View file @
5d364e53
...
@@ -2935,7 +2935,7 @@ bool Item_exists_subselect::exists2in_processor(uchar *opt_arg)
...
@@ -2935,7 +2935,7 @@ bool Item_exists_subselect::exists2in_processor(uchar *opt_arg)
res
=
TRUE
;
res
=
TRUE
;
goto
out
;
goto
out
;
}
}
for
(
in
t
i
=
0
;
i
<
eqs
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
eqs
.
elements
();
i
++
)
{
{
if
(
optimizer
->
arguments
()[
0
]
->
maybe_null
)
if
(
optimizer
->
arguments
()[
0
]
->
maybe_null
)
{
{
...
...
sql/sql_array.h
View file @
5d364e53
...
@@ -104,7 +104,7 @@ public:
...
@@ -104,7 +104,7 @@ public:
MYF
(
MY_THREAD_SPECIFIC
));
MYF
(
MY_THREAD_SPECIFIC
));
}
}
Elem
&
at
(
in
t
idx
)
Elem
&
at
(
size_
t
idx
)
{
{
return
*
(((
Elem
*
)
array
.
buffer
)
+
idx
);
return
*
(((
Elem
*
)
array
.
buffer
)
+
idx
);
}
}
...
@@ -129,11 +129,16 @@ public:
...
@@ -129,11 +129,16 @@ public:
return
(
insert_dynamic
(
&
array
,
(
uchar
*
)
&
el
));
return
(
insert_dynamic
(
&
array
,
(
uchar
*
)
&
el
));
}
}
in
t
elements
()
size_
t
elements
()
{
{
return
array
.
elements
;
return
array
.
elements
;
}
}
void
set_elements
(
size_t
n
)
{
array
.
elements
=
n
;
}
~
Dynamic_array
()
~
Dynamic_array
()
{
{
delete_dynamic
(
&
array
);
delete_dynamic
(
&
array
);
...
...
sql/sql_show.cc
View file @
5d364e53
...
@@ -687,59 +687,6 @@ db_name_is_in_ignore_db_dirs_list(const char *directory)
...
@@ -687,59 +687,6 @@ db_name_is_in_ignore_db_dirs_list(const char *directory)
return
my_hash_search
(
&
ignore_db_dirs_hash
,
(
uchar
*
)
buff
,
buff_len
)
!=
NULL
;
return
my_hash_search
(
&
ignore_db_dirs_hash
,
(
uchar
*
)
buff
,
buff_len
)
!=
NULL
;
}
}
class
Discovered_table_list
:
public
handlerton
::
discovered_list
{
THD
*
thd
;
const
char
*
wild
;
size_t
wild_length
;
Dynamic_array
<
LEX_STRING
*>
*
tables
;
public:
Discovered_table_list
(
THD
*
thd_arg
,
Dynamic_array
<
LEX_STRING
*>
*
tables_arg
,
const
char
*
wild_arg
)
{
thd
=
thd_arg
;
tables
=
tables_arg
;
if
(
wild_arg
&&
wild_arg
[
0
])
{
wild
=
wild_arg
;
wild_length
=
strlen
(
wild_arg
);
}
else
wild
=
0
;
}
~
Discovered_table_list
()
{}
bool
add_table
(
const
char
*
tname
,
size_t
tlen
)
{
if
(
wild
&&
my_wildcmp
(
files_charset_info
,
tname
,
tname
+
tlen
,
wild
,
wild
+
wild_length
,
wild_prefix
,
wild_one
,
wild_many
))
return
0
;
LEX_STRING
*
name
=
thd
->
make_lex_string
(
tname
,
tlen
);
if
(
!
name
||
tables
->
append
(
name
))
return
1
;
return
0
;
}
bool
add_file
(
const
char
*
fname
)
{
char
tname
[
SAFE_NAME_LEN
+
1
];
size_t
tlen
=
filename_to_tablename
(
fname
,
tname
,
sizeof
(
tname
));
return
add_table
(
tname
,
tlen
);
}
};
extern
"C"
{
static
int
cmp_table_names
(
LEX_STRING
*
const
*
a
,
LEX_STRING
*
const
*
b
)
{
return
my_strnncoll
(
&
my_charset_bin
,
(
const
uchar
*
)((
*
a
)
->
str
),
(
*
a
)
->
length
,
(
const
uchar
*
)((
*
b
)
->
str
),
(
*
b
)
->
length
);
}
}
enum
find_files_result
{
enum
find_files_result
{
FIND_FILES_OK
,
FIND_FILES_OK
,
FIND_FILES_OOM
,
FIND_FILES_OOM
,
...
@@ -767,20 +714,13 @@ enum find_files_result {
...
@@ -767,20 +714,13 @@ enum find_files_result {
static
find_files_result
static
find_files_result
find_files
(
THD
*
thd
,
Dynamic_array
<
LEX_STRING
*>
*
files
,
LEX_STRING
*
db
,
find_files
(
THD
*
thd
,
Dynamic_array
<
LEX_STRING
*>
*
files
,
LEX_STRING
*
db
,
const
char
*
path
,
const
char
*
wild
)
const
char
*
path
,
const
LEX_STRING
*
wild
)
{
{
MY_DIR
*
dirp
;
MY_DIR
*
dirp
;
myf
my_dir_flags
=
MY_THREAD_SPECIFIC
;
Discovered_table_list
tl
(
thd
,
files
,
wild
);
Discovered_table_list
tl
(
thd
,
files
,
wild
);
DBUG_ENTER
(
"find_files"
);
DBUG_ENTER
(
"find_files"
);
if
(
!
db
)
if
(
!
(
dirp
=
my_dir
(
path
,
MY_THREAD_SPECIFIC
|
(
db
?
0
:
MY_WANT_STAT
))))
my_dir_flags
|=
MY_WANT_STAT
;
if
(
engines_with_discover_table_names
)
my_dir_flags
|=
MY_WANT_SORT
;
if
(
!
(
dirp
=
my_dir
(
path
,
my_dir_flags
)))
{
{
if
(
my_errno
==
ENOENT
)
if
(
my_errno
==
ENOENT
)
my_error
(
ER_BAD_DB_ERROR
,
MYF
(
ME_BELL
|
ME_WAITTANG
),
db
->
str
);
my_error
(
ER_BAD_DB_ERROR
,
MYF
(
ME_BELL
|
ME_WAITTANG
),
db
->
str
);
...
@@ -819,6 +759,7 @@ find_files(THD *thd, Dynamic_array<LEX_STRING*> *files, LEX_STRING *db,
...
@@ -819,6 +759,7 @@ find_files(THD *thd, Dynamic_array<LEX_STRING*> *files, LEX_STRING *db,
if
(
tl
.
add_file
(
file
->
name
))
if
(
tl
.
add_file
(
file
->
name
))
goto
err
;
goto
err
;
}
}
tl
.
sort
();
}
}
else
else
{
{
...
@@ -826,11 +767,9 @@ find_files(THD *thd, Dynamic_array<LEX_STRING*> *files, LEX_STRING *db,
...
@@ -826,11 +767,9 @@ find_files(THD *thd, Dynamic_array<LEX_STRING*> *files, LEX_STRING *db,
goto
err
;
goto
err
;
}
}
DBUG_PRINT
(
"info"
,(
"found: %
d
files"
,
files
->
elements
()));
DBUG_PRINT
(
"info"
,(
"found: %
zu
files"
,
files
->
elements
()));
my_dirend
(
dirp
);
my_dirend
(
dirp
);
files
->
sort
(
cmp_table_names
);
DBUG_RETURN
(
FIND_FILES_OK
);
DBUG_RETURN
(
FIND_FILES_OK
);
err:
err:
...
@@ -3716,7 +3655,7 @@ int make_db_list(THD *thd, Dynamic_array<LEX_STRING*> *files,
...
@@ -3716,7 +3655,7 @@ int make_db_list(THD *thd, Dynamic_array<LEX_STRING*> *files,
return
1
;
return
1
;
}
}
return
find_files
(
thd
,
files
,
0
,
mysql_data_home
,
return
find_files
(
thd
,
files
,
0
,
mysql_data_home
,
lookup_field_vals
->
db_value
.
str
);
&
lookup_field_vals
->
db_value
);
}
}
...
@@ -3747,7 +3686,7 @@ int make_db_list(THD *thd, Dynamic_array<LEX_STRING*> *files,
...
@@ -3747,7 +3686,7 @@ int make_db_list(THD *thd, Dynamic_array<LEX_STRING*> *files,
*/
*/
if
(
files
->
append_val
(
&
INFORMATION_SCHEMA_NAME
))
if
(
files
->
append_val
(
&
INFORMATION_SCHEMA_NAME
))
return
1
;
return
1
;
return
find_files
(
thd
,
files
,
0
,
mysql_data_home
,
NullS
);
return
find_files
(
thd
,
files
,
0
,
mysql_data_home
,
&
null_lex_str
);
}
}
...
@@ -3891,7 +3830,7 @@ make_table_name_list(THD *thd, Dynamic_array<LEX_STRING*> *table_names,
...
@@ -3891,7 +3830,7 @@ make_table_name_list(THD *thd, Dynamic_array<LEX_STRING*> *table_names,
lookup_field_vals
->
table_value
.
str
));
lookup_field_vals
->
table_value
.
str
));
find_files_result
res
=
find_files
(
thd
,
table_names
,
db_name
,
path
,
find_files_result
res
=
find_files
(
thd
,
table_names
,
db_name
,
path
,
lookup_field_vals
->
table_value
.
str
);
&
lookup_field_vals
->
table_value
);
if
(
res
!=
FIND_FILES_OK
)
if
(
res
!=
FIND_FILES_OK
)
{
{
/*
/*
...
@@ -4633,7 +4572,7 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond)
...
@@ -4633,7 +4572,7 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond)
if
(
make_db_list
(
thd
,
&
db_names
,
&
lookup_field_vals
))
if
(
make_db_list
(
thd
,
&
db_names
,
&
lookup_field_vals
))
goto
err
;
goto
err
;
for
(
in
t
i
=
0
;
i
<
db_names
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
db_names
.
elements
();
i
++
)
{
{
LEX_STRING
*
db_name
=
db_names
.
at
(
i
);
LEX_STRING
*
db_name
=
db_names
.
at
(
i
);
#ifndef NO_EMBEDDED_ACCESS_CHECKS
#ifndef NO_EMBEDDED_ACCESS_CHECKS
...
@@ -4652,7 +4591,7 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond)
...
@@ -4652,7 +4591,7 @@ int get_all_tables(THD *thd, TABLE_LIST *tables, COND *cond)
if
(
res
)
if
(
res
)
goto
err
;
goto
err
;
for
(
in
t
i
=
0
;
i
<
table_names
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
table_names
.
elements
();
i
++
)
{
{
LEX_STRING
*
table_name
=
table_names
.
at
(
i
);
LEX_STRING
*
table_name
=
table_names
.
at
(
i
);
...
@@ -4800,7 +4739,7 @@ int fill_schema_schemata(THD *thd, TABLE_LIST *tables, COND *cond)
...
@@ -4800,7 +4739,7 @@ int fill_schema_schemata(THD *thd, TABLE_LIST *tables, COND *cond)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
for
(
in
t
i
=
0
;
i
<
db_names
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
db_names
.
elements
();
i
++
)
{
{
LEX_STRING
*
db_name
=
db_names
.
at
(
i
);
LEX_STRING
*
db_name
=
db_names
.
at
(
i
);
if
(
db_name
==
&
INFORMATION_SCHEMA_NAME
)
if
(
db_name
==
&
INFORMATION_SCHEMA_NAME
)
...
...
storage/sphinx/ha_sphinx.cc
View file @
5d364e53
...
@@ -1285,7 +1285,7 @@ CSphSEQuery::~CSphSEQuery ()
...
@@ -1285,7 +1285,7 @@ CSphSEQuery::~CSphSEQuery ()
SafeDeleteArray
(
m_sQueryBuffer
);
SafeDeleteArray
(
m_sQueryBuffer
);
SafeDeleteArray
(
m_pWeights
);
SafeDeleteArray
(
m_pWeights
);
SafeDeleteArray
(
m_pBuf
);
SafeDeleteArray
(
m_pBuf
);
for
(
in
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
SafeDelete
(
m_dOverrides
.
at
(
i
)
);
SafeDelete
(
m_dOverrides
.
at
(
i
)
);
SPH_VOID_RET
();
SPH_VOID_RET
();
}
}
...
@@ -1865,7 +1865,7 @@ int CSphSEQuery::BuildRequest ( char ** ppBuffer )
...
@@ -1865,7 +1865,7 @@ int CSphSEQuery::BuildRequest ( char ** ppBuffer )
iReqSize
+=
8
+
strlen
(
m_sFieldWeight
[
i
]
);
iReqSize
+=
8
+
strlen
(
m_sFieldWeight
[
i
]
);
// overrides
// overrides
iReqSize
+=
4
;
iReqSize
+=
4
;
for
(
in
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
{
{
CSphSEQuery
::
Override_t
*
pOverride
=
m_dOverrides
.
at
(
i
);
CSphSEQuery
::
Override_t
*
pOverride
=
m_dOverrides
.
at
(
i
);
const
uint32
uSize
=
pOverride
->
m_iType
==
SPH_ATTR_BIGINT
?
16
:
12
;
// id64 + value
const
uint32
uSize
=
pOverride
->
m_iType
==
SPH_ATTR_BIGINT
?
16
:
12
;
// id64 + value
...
@@ -1972,13 +1972,13 @@ int CSphSEQuery::BuildRequest ( char ** ppBuffer )
...
@@ -1972,13 +1972,13 @@ int CSphSEQuery::BuildRequest ( char ** ppBuffer )
// overrides
// overrides
SendInt
(
m_dOverrides
.
elements
()
);
SendInt
(
m_dOverrides
.
elements
()
);
for
(
in
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
for
(
size_
t
i
=
0
;
i
<
m_dOverrides
.
elements
();
i
++
)
{
{
CSphSEQuery
::
Override_t
*
pOverride
=
m_dOverrides
.
at
(
i
);
CSphSEQuery
::
Override_t
*
pOverride
=
m_dOverrides
.
at
(
i
);
SendString
(
pOverride
->
m_sName
);
SendString
(
pOverride
->
m_sName
);
SendDword
(
pOverride
->
m_iType
);
SendDword
(
pOverride
->
m_iType
);
SendInt
(
pOverride
->
m_dIds
.
elements
()
);
SendInt
(
pOverride
->
m_dIds
.
elements
()
);
for
(
in
t
j
=
0
;
j
<
pOverride
->
m_dIds
.
elements
();
j
++
)
for
(
size_
t
j
=
0
;
j
<
pOverride
->
m_dIds
.
elements
();
j
++
)
{
{
SendUint64
(
pOverride
->
m_dIds
.
at
(
j
)
);
SendUint64
(
pOverride
->
m_dIds
.
at
(
j
)
);
if
(
pOverride
->
m_iType
==
SPH_ATTR_FLOAT
)
if
(
pOverride
->
m_iType
==
SPH_ATTR_FLOAT
)
...
...
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