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
f9639c2d
Commit
f9639c2d
authored
Mar 19, 2020
by
Oleksandr Byelkin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-22037: Add ability to skip content of some tables (work around for MDEV-20939)
--ignore-table-data parameter added.
parent
1f7be881
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
92 additions
and
6 deletions
+92
-6
client/client_priv.h
client/client_priv.h
+1
-0
client/mysqldump.c
client/mysqldump.c
+36
-6
mysql-test/r/mysqldump.result
mysql-test/r/mysqldump.result
+19
-0
mysql-test/t/mysqldump.test
mysql-test/t/mysqldump.test
+36
-0
No files found.
client/client_priv.h
View file @
f9639c2d
...
@@ -93,6 +93,7 @@ enum options_client
...
@@ -93,6 +93,7 @@ enum options_client
OPT_REPORT_PROGRESS
,
OPT_REPORT_PROGRESS
,
OPT_SKIP_ANNOTATE_ROWS_EVENTS
,
OPT_SKIP_ANNOTATE_ROWS_EVENTS
,
OPT_SSL_CRL
,
OPT_SSL_CRLPATH
,
OPT_SSL_CRL
,
OPT_SSL_CRLPATH
,
OPT_IGNORE_DATA
,
OPT_MAX_CLIENT_OPTION
/* should be always the last */
OPT_MAX_CLIENT_OPTION
/* should be always the last */
};
};
...
...
client/mysqldump.c
View file @
f9639c2d
...
@@ -90,6 +90,7 @@
...
@@ -90,6 +90,7 @@
/* Max length GTID position that we will output. */
/* Max length GTID position that we will output. */
#define MAX_GTID_LENGTH 1024
#define MAX_GTID_LENGTH 1024
static
my_bool
ignore_table_data
(
const
uchar
*
hash_key
,
size_t
len
);
static
void
add_load_option
(
DYNAMIC_STRING
*
str
,
const
char
*
option
,
static
void
add_load_option
(
DYNAMIC_STRING
*
str
,
const
char
*
option
,
const
char
*
option_value
);
const
char
*
option_value
);
static
ulong
find_set
(
TYPELIB
*
,
const
char
*
,
size_t
,
char
**
,
uint
*
);
static
ulong
find_set
(
TYPELIB
*
,
const
char
*
,
size_t
,
char
**
,
uint
*
);
...
@@ -210,7 +211,7 @@ TYPELIB compatible_mode_typelib= {array_elements(compatible_mode_names) - 1,
...
@@ -210,7 +211,7 @@ TYPELIB compatible_mode_typelib= {array_elements(compatible_mode_names) - 1,
#define MED_ENGINES "MRG_MyISAM, MRG_ISAM, CONNECT, OQGRAPH, SPIDER, VP, FEDERATED"
#define MED_ENGINES "MRG_MyISAM, MRG_ISAM, CONNECT, OQGRAPH, SPIDER, VP, FEDERATED"
HASH
ignore_table
;
HASH
ignore_table
,
ignore_data
;
static
struct
my_option
my_long_options
[]
=
static
struct
my_option
my_long_options
[]
=
{
{
...
@@ -371,6 +372,12 @@ static struct my_option my_long_options[] =
...
@@ -371,6 +372,12 @@ static struct my_option my_long_options[] =
&
opt_hex_blob
,
&
opt_hex_blob
,
0
,
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
&
opt_hex_blob
,
&
opt_hex_blob
,
0
,
GET_BOOL
,
NO_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"host"
,
'h'
,
"Connect to host."
,
&
current_host
,
{
"host"
,
'h'
,
"Connect to host."
,
&
current_host
,
&
current_host
,
0
,
GET_STR_ALLOC
,
REQUIRED_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
&
current_host
,
0
,
GET_STR_ALLOC
,
REQUIRED_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"ignore-table-data"
,
OPT_IGNORE_DATA
,
"Do not dump the specified table data. To specify more than one table "
"to ignore, use the directive multiple times, once for each table. "
"Each table must be specified with both database and table names, e.g., "
"--ignore-table-data=database.table."
,
0
,
0
,
0
,
GET_STR
,
REQUIRED_ARG
,
0
,
0
,
0
,
0
,
0
,
0
},
{
"ignore-table"
,
OPT_IGNORE_TABLE
,
{
"ignore-table"
,
OPT_IGNORE_TABLE
,
"Do not dump the specified table. To specify more than one table to ignore, "
"Do not dump the specified table. To specify more than one table to ignore, "
"use the directive multiple times, once for each table. Each table must "
"use the directive multiple times, once for each table. Each table must "
...
@@ -895,6 +902,18 @@ get_one_option(int optid, const struct my_option *opt __attribute__((unused)),
...
@@ -895,6 +902,18 @@ get_one_option(int optid, const struct my_option *opt __attribute__((unused)),
case
(
int
)
OPT_TABLES
:
case
(
int
)
OPT_TABLES
:
opt_databases
=
0
;
opt_databases
=
0
;
break
;
break
;
case
(
int
)
OPT_IGNORE_DATA
:
{
if
(
!
strchr
(
argument
,
'.'
))
{
fprintf
(
stderr
,
"Illegal use of option --ignore-table-data=<database>.<table>
\n
"
);
exit
(
1
);
}
if
(
my_hash_insert
(
&
ignore_data
,
(
uchar
*
)
my_strdup
(
argument
,
MYF
(
0
))))
exit
(
EX_EOM
);
break
;
}
case
(
int
)
OPT_IGNORE_TABLE
:
case
(
int
)
OPT_IGNORE_TABLE
:
{
{
if
(
!
strchr
(
argument
,
'.'
))
if
(
!
strchr
(
argument
,
'.'
))
...
@@ -993,6 +1012,10 @@ static int get_options(int *argc, char ***argv)
...
@@ -993,6 +1012,10 @@ static int get_options(int *argc, char ***argv)
(
uchar
*
)
my_strdup
(
"mysql.slow_log"
,
MYF
(
MY_WME
))))
(
uchar
*
)
my_strdup
(
"mysql.slow_log"
,
MYF
(
MY_WME
))))
return
(
EX_EOM
);
return
(
EX_EOM
);
if
(
my_hash_init
(
&
ignore_data
,
charset_info
,
16
,
0
,
0
,
(
my_hash_get_key
)
get_table_key
,
my_free
,
0
))
return
(
EX_EOM
);
if
((
ho_error
=
handle_options
(
argc
,
argv
,
my_long_options
,
get_one_option
)))
if
((
ho_error
=
handle_options
(
argc
,
argv
,
my_long_options
,
get_one_option
)))
return
(
ho_error
);
return
(
ho_error
);
...
@@ -1637,6 +1660,8 @@ static void free_resources()
...
@@ -1637,6 +1660,8 @@ static void free_resources()
free_root
(
&
glob_root
,
MYF
(
0
));
free_root
(
&
glob_root
,
MYF
(
0
));
if
(
my_hash_inited
(
&
ignore_table
))
if
(
my_hash_inited
(
&
ignore_table
))
my_hash_free
(
&
ignore_table
);
my_hash_free
(
&
ignore_table
);
if
(
my_hash_inited
(
&
ignore_data
))
my_hash_free
(
&
ignore_data
);
dynstr_free
(
&
extended_row
);
dynstr_free
(
&
extended_row
);
dynstr_free
(
&
dynamic_where
);
dynstr_free
(
&
dynamic_where
);
dynstr_free
(
&
insert_pat
);
dynstr_free
(
&
insert_pat
);
...
@@ -3601,7 +3626,7 @@ static char *alloc_query_str(ulong size)
...
@@ -3601,7 +3626,7 @@ static char *alloc_query_str(ulong size)
*/
*/
static
void
dump_table
(
char
*
table
,
char
*
db
)
static
void
dump_table
(
char
*
table
,
char
*
db
,
const
uchar
*
hash_key
,
size_t
len
)
{
{
char
ignore_flag
;
char
ignore_flag
;
char
buf
[
200
],
table_buff
[
NAME_LEN
+
3
];
char
buf
[
200
],
table_buff
[
NAME_LEN
+
3
];
...
@@ -3629,7 +3654,7 @@ static void dump_table(char *table, char *db)
...
@@ -3629,7 +3654,7 @@ static void dump_table(char *table, char *db)
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
/* Check --no-data flag */
/* Check --no-data flag */
if
(
opt_no_data
)
if
(
opt_no_data
||
(
hash_key
&&
ignore_table_data
(
hash_key
,
len
))
)
{
{
verbose_msg
(
"-- Skipping dump data for table '%s', --no-data was used
\n
"
,
verbose_msg
(
"-- Skipping dump data for table '%s', --no-data was used
\n
"
,
table
);
table
);
...
@@ -4557,10 +4582,14 @@ static int init_dumping(char *database, int init_func(char*))
...
@@ -4557,10 +4582,14 @@ static int init_dumping(char *database, int init_func(char*))
/* Return 1 if we should copy the table */
/* Return 1 if we should copy the table */
my_bool
include_table
(
const
uchar
*
hash_key
,
size_t
len
)
static
my_bool
include_table
(
const
uchar
*
hash_key
,
size_t
len
)
{
{
return
!
my_hash_search
(
&
ignore_table
,
hash_key
,
len
);
return
!
my_hash_search
(
&
ignore_table
,
hash_key
,
len
);
}
}
static
my_bool
ignore_table_data
(
const
uchar
*
hash_key
,
size_t
len
)
{
return
my_hash_search
(
&
ignore_data
,
hash_key
,
len
)
!=
NULL
;
}
static
int
dump_all_tables_in_db
(
char
*
database
)
static
int
dump_all_tables_in_db
(
char
*
database
)
...
@@ -4625,7 +4654,7 @@ static int dump_all_tables_in_db(char *database)
...
@@ -4625,7 +4654,7 @@ static int dump_all_tables_in_db(char *database)
char
*
end
=
strmov
(
afterdot
,
table
);
char
*
end
=
strmov
(
afterdot
,
table
);
if
(
include_table
((
uchar
*
)
hash_key
,
end
-
hash_key
))
if
(
include_table
((
uchar
*
)
hash_key
,
end
-
hash_key
))
{
{
dump_table
(
table
,
database
);
dump_table
(
table
,
database
,
(
uchar
*
)
hash_key
,
end
-
hash_key
);
my_free
(
order_by
);
my_free
(
order_by
);
order_by
=
0
;
order_by
=
0
;
if
(
opt_dump_triggers
&&
mysql_get_server_version
(
mysql
)
>=
50009
)
if
(
opt_dump_triggers
&&
mysql_get_server_version
(
mysql
)
>=
50009
)
...
@@ -5014,7 +5043,7 @@ static int dump_selected_tables(char *db, char **table_names, int tables)
...
@@ -5014,7 +5043,7 @@ static int dump_selected_tables(char *db, char **table_names, int tables)
for
(
pos
=
dump_tables
;
pos
<
end
;
pos
++
)
for
(
pos
=
dump_tables
;
pos
<
end
;
pos
++
)
{
{
DBUG_PRINT
(
"info"
,(
"Dumping table %s"
,
*
pos
));
DBUG_PRINT
(
"info"
,(
"Dumping table %s"
,
*
pos
));
dump_table
(
*
pos
,
db
);
dump_table
(
*
pos
,
db
,
NULL
,
0
);
if
(
opt_dump_triggers
&&
if
(
opt_dump_triggers
&&
mysql_get_server_version
(
mysql
)
>=
50009
)
mysql_get_server_version
(
mysql
)
>=
50009
)
{
{
...
@@ -5995,6 +6024,7 @@ int main(int argc, char **argv)
...
@@ -5995,6 +6024,7 @@ int main(int argc, char **argv)
compatible_mode_normal_str
[
0
]
=
0
;
compatible_mode_normal_str
[
0
]
=
0
;
default_charset
=
(
char
*
)
mysql_universal_client_charset
;
default_charset
=
(
char
*
)
mysql_universal_client_charset
;
bzero
((
char
*
)
&
ignore_table
,
sizeof
(
ignore_table
));
bzero
((
char
*
)
&
ignore_table
,
sizeof
(
ignore_table
));
bzero
((
char
*
)
&
ignore_data
,
sizeof
(
ignore_data
));
exit_code
=
get_options
(
&
argc
,
&
argv
);
exit_code
=
get_options
(
&
argc
,
&
argv
);
if
(
exit_code
)
if
(
exit_code
)
...
...
mysql-test/r/mysqldump.result
View file @
f9639c2d
...
@@ -5628,3 +5628,22 @@ select count(*) from t2;
...
@@ -5628,3 +5628,22 @@ select count(*) from t2;
count(*)
count(*)
2
2
drop tables t2, t1;
drop tables t2, t1;
#
# MDEV-22037: Add ability to skip content of some tables
# (work around for MDEV-20939)
#
use mysql;
# check that all tables we need are not empty
select count(*) >= 1 from mysql.proc;
count(*) >= 1
1
select count(*) >= 1 from mysql.db;
count(*) >= 1
1
# for proc we have CREATE and INSERT for all other only CREATE
FOUND /INSERT INTO `proc`/ in MDEV-20939.sql
NOT FOUND /INSERT INTO `db`/ in MDEV-20939.sql
FOUND /CREATE TABLE `db`/ in MDEV-20939.sql
FOUND /CREATE TABLE `proc`/ in MDEV-20939.sql
use test;
# End of 10.1 tests
mysql-test/t/mysqldump.test
View file @
f9639c2d
...
@@ -2678,3 +2678,39 @@ select count(*) from t2;
...
@@ -2678,3 +2678,39 @@ select count(*) from t2;
--
remove_file
$MYSQLTEST_VARDIR
/
tmp
/
t2
.
txt
--
remove_file
$MYSQLTEST_VARDIR
/
tmp
/
t2
.
txt
drop
tables
t2
,
t1
;
drop
tables
t2
,
t1
;
--
echo
#
--
echo
# MDEV-22037: Add ability to skip content of some tables
--
echo
# (work around for MDEV-20939)
--
echo
#
use
mysql
;
--
echo
# check that all tables we need are not empty
select
count
(
*
)
>=
1
from
mysql
.
proc
;
select
count
(
*
)
>=
1
from
mysql
.
db
;
--
exec
$MYSQL_DUMP
mysql
--
ignore
-
table
-
data
=
mysql
.
db
>
$MYSQLTEST_VARDIR
/
tmp
/
MDEV
-
20939.
sql
--
echo
# for proc we have CREATE and INSERT for all other only CREATE
let
SEARCH_RANGE
=
500000000
;
let
SEARCH_FILE
=
$MYSQLTEST_VARDIR
/
tmp
/
MDEV
-
20939.
sql
;
let
SEARCH_PATTERN
=
INSERT
INTO
`proc`
;
source
include
/
search_pattern_in_file
.
inc
;
let
SEARCH_PATTERN
=
INSERT
INTO
`db`
;
source
include
/
search_pattern_in_file
.
inc
;
let
SEARCH_PATTERN
=
CREATE
TABLE
`db`
;
source
include
/
search_pattern_in_file
.
inc
;
let
SEARCH_PATTERN
=
CREATE
TABLE
`proc`
;
source
include
/
search_pattern_in_file
.
inc
;
--
remove_file
$MYSQLTEST_VARDIR
/
tmp
/
MDEV
-
20939.
sql
use
test
;
--
echo
# End of 10.1 tests
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