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
792e46d5
Commit
792e46d5
authored
Sep 13, 2005
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-5.0
into serg.mylan:/usr/home/serg/Abk/mysql-5.0
parents
a1d03c13
2d146983
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
74 additions
and
82 deletions
+74
-82
client/mysqldump.c
client/mysqldump.c
+24
-39
mysql-test/r/mysqldump.result
mysql-test/r/mysqldump.result
+27
-21
mysql-test/t/mysqldump.test
mysql-test/t/mysqldump.test
+23
-22
No files found.
client/mysqldump.c
View file @
792e46d5
...
@@ -1193,12 +1193,11 @@ static void print_xml_row(FILE *xml_file, const char *row_name,
...
@@ -1193,12 +1193,11 @@ static void print_xml_row(FILE *xml_file, const char *row_name,
static
uint
dump_routines_for_db
(
char
*
db
)
static
uint
dump_routines_for_db
(
char
*
db
)
{
{
char
query_buff
[
512
],
routine_type
[
10
]
;
char
query_buff
[
512
],
*
routine_type
[]
=
{
"FUNCTION"
,
"PROCEDURE"
}
;
char
db_name_buff
[
NAME_LEN
+
3
],
name_buff
[
NAME_LEN
+
3
]
;
char
db_name_buff
[
NAME_LEN
*
2
+
3
],
name_buff
[
NAME_LEN
*
2
+
3
],
*
routine_name
;
int
i
;
int
i
;
FILE
*
sql_file
=
md_result_file
;
FILE
*
sql_file
=
md_result_file
;
MYSQL_RES
*
routine_res
=
NULL
;
MYSQL_RES
*
routine_res
,
*
routine_list_res
;
MYSQL_RES
*
routine_list_res
=
NULL
;
MYSQL_ROW
row
,
routine_list_row
;
MYSQL_ROW
row
,
routine_list_row
;
DBUG_ENTER
(
"dump_routines_for_db"
);
DBUG_ENTER
(
"dump_routines_for_db"
);
...
@@ -1211,23 +1210,20 @@ static uint dump_routines_for_db (char *db)
...
@@ -1211,23 +1210,20 @@ static uint dump_routines_for_db (char *db)
fprintf
(
sql_file
,
"
\n
--
\n
-- Dumping routines for database '%s'
\n
--
\n
"
,
db
);
fprintf
(
sql_file
,
"
\n
--
\n
-- Dumping routines for database '%s'
\n
--
\n
"
,
db
);
/*
/*
not using "mysql_query_with_error_report" because of privileges
not using "mysql_query_with_error_report" because we may have not
enough privileges to lock mysql.proc.
*/
*/
if
(
opt_lock
)
if
(
lock_tables
)
mysql_query
(
sock
,
"LOCK TABLES mysql.proc READ"
);
mysql_query
(
sock
,
"LOCK TABLES mysql.proc READ"
);
fprintf
(
sql_file
,
"
\n
/*!50003 SET @OLD_SQL_MODE=@@SQL_MODE*/;
\n
"
);
fprintf
(
sql_file
,
"DELIMITER //
\n
"
);
fprintf
(
sql_file
,
"DELIMITER //
\n
"
);
/* 0, retrieve and dump functions, 1, procedures */
/* 0, retrieve and dump functions, 1, procedures */
for
(
i
=
0
;
i
<=
1
;
i
++
)
for
(
i
=
0
;
i
<=
1
;
i
++
)
{
{
my_snprintf
(
routine_type
,
sizeof
(
routine_type
),
"%s"
,
i
==
0
?
"FUNCTION"
:
"PROCEDURE"
);
my_snprintf
(
query_buff
,
sizeof
(
query_buff
),
my_snprintf
(
query_buff
,
sizeof
(
query_buff
),
"SHOW %s STATUS WHERE Db = '%s'"
,
"SHOW %s STATUS WHERE Db = '%s'"
,
routine_type
,
db_name_buff
);
routine_type
[
i
]
,
db_name_buff
);
if
(
mysql_query_with_error_report
(
sock
,
&
routine_list_res
,
query_buff
))
if
(
mysql_query_with_error_report
(
sock
,
&
routine_list_res
,
query_buff
))
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
...
@@ -1237,11 +1233,11 @@ static uint dump_routines_for_db (char *db)
...
@@ -1237,11 +1233,11 @@ static uint dump_routines_for_db (char *db)
while
((
routine_list_row
=
mysql_fetch_row
(
routine_list_res
)))
while
((
routine_list_row
=
mysql_fetch_row
(
routine_list_res
)))
{
{
DBUG_PRINT
(
"info"
,
(
"retrieving CREATE %s for %s"
,
routine_type
,
name_buff
));
DBUG_PRINT
(
"info"
,
(
"retrieving CREATE %s for %s"
,
routine_type
[
i
],
mysql_real_escape_string
(
sock
,
name_buff
,
name_buff
));
routine_list_row
[
1
],
strlen
(
routine_list_row
[
1
])
);
routine_name
=
quote_name
(
routine_list_row
[
1
],
name_buff
,
0
);
my_snprintf
(
query_buff
,
sizeof
(
query_buff
),
"SHOW CREATE %s %s"
,
my_snprintf
(
query_buff
,
sizeof
(
query_buff
),
"SHOW CREATE %s %s"
,
routine_type
,
name_buff
);
routine_type
[
i
],
routine_name
);
if
(
mysql_query_with_error_report
(
sock
,
&
routine_res
,
query_buff
))
if
(
mysql_query_with_error_report
(
sock
,
&
routine_res
,
query_buff
))
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
...
@@ -1249,41 +1245,36 @@ static uint dump_routines_for_db (char *db)
...
@@ -1249,41 +1245,36 @@ static uint dump_routines_for_db (char *db)
while
((
row
=
mysql_fetch_row
(
routine_res
)))
while
((
row
=
mysql_fetch_row
(
routine_res
)))
{
{
/*
/*
the user can see routine names, but NOT the routine body of other
if the user has EXECUTE privilege he see routine names, but NOT the
routines that are not the creator of!
routine
body of other routine
s that are not the creator of!
*/
*/
DBUG_PRINT
(
"info"
,(
"length of body for %s row[2] '%s' is %d"
,
DBUG_PRINT
(
"info"
,(
"length of body for %s row[2] '%s' is %d"
,
name_buff
,
row
[
2
],
strlen
(
row
[
2
])));
routine_name
,
row
[
2
],
strlen
(
row
[
2
])));
if
(
strlen
(
row
[
2
]))
if
(
strlen
(
row
[
2
]))
{
{
fprintf
(
sql_file
,
"/*!50003 SET SESSION SQL_MODE=
\"
%s
\"
*/ //
\n
"
,
row
[
1
]
/* sql_mode */
);
if
(
opt_drop
)
if
(
opt_drop
)
fprintf
(
sql_file
,
"/*!50003 DROP %s IF EXISTS %s */ //
\n
"
,
fprintf
(
sql_file
,
"/*!50003 DROP %s IF EXISTS %s */ //
\n
"
,
routine_type
,
name_buff
);
routine_type
[
i
],
routine_name
);
/*
/*
the i==0 is temporary until we can figure out why functions
we need to change sql_mode only for the CREATE PROCEDURE/FUNCTION
can't be in comments
otherwise we may need to re-quote routine_name
*/
*/
;
/* create proc/func body */
;
fprintf
(
sql_file
,
"/*!50003 SET SESSION SQL_MODE=
\"
%s
\"
*/ //
\n
"
,
row
[
1
]
/* sql_mode */
);
fprintf
(
sql_file
,
"/*!50003 %s */ //
\n
"
,
row
[
2
]);
fprintf
(
sql_file
,
"/*!50003 %s */ //
\n
"
,
row
[
2
]);
fprintf
(
sql_file
,
"/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
\n
"
);
}
}
}
/* end of routine printing */
}
/* end of routine printing */
}
/* end of list of routines */
}
/* end of list of routines */
mysql_free_result
(
routine_res
);
mysql_free_result
(
routine_res
);
routine_res
=
NULL
;
}
}
mysql_free_result
(
routine_list_res
);
mysql_free_result
(
routine_list_res
);
routine_list_res
=
NULL
;
}
/* end of for i (0 .. 1) */
}
/* end of for i (0 .. 1) */
/* set the delimiter back to ';' */
/* set the delimiter back to ';' */
fprintf
(
sql_file
,
"DELIMITER ;
\n
"
);
fprintf
(
sql_file
,
"DELIMITER ;
\n
"
);
fprintf
(
sql_file
,
"/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/;
\n
"
);
/* again, no error report due to permissions */
if
(
lock_tables
)
if
(
opt_lock
)
mysql_query_with_error_report
(
sock
,
0
,
"UNLOCK TABLES"
);
mysql_query
(
sock
,
"UNLOCK TABLES"
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
@@ -1739,12 +1730,6 @@ static uint get_table_structure(char *table, char *db)
...
@@ -1739,12 +1730,6 @@ static uint get_table_structure(char *table, char *db)
the tables have been dumped in case a trigger depends on the existence
the tables have been dumped in case a trigger depends on the existence
of a table
of a table
INPUT
char * tablename and db name
RETURNS
0 Failure
1 Succes
*/
*/
static
void
dump_triggers_for_table
(
char
*
table
,
char
*
db
)
static
void
dump_triggers_for_table
(
char
*
table
,
char
*
db
)
...
@@ -1752,7 +1737,7 @@ static void dump_triggers_for_table (char *table, char *db)
...
@@ -1752,7 +1737,7 @@ static void dump_triggers_for_table (char *table, char *db)
MYSQL_RES
*
result
;
MYSQL_RES
*
result
;
MYSQL_ROW
row
;
MYSQL_ROW
row
;
char
*
result_table
;
char
*
result_table
;
char
name_buff
[
NAME_LEN
+
3
],
table_buff
[
NAME_LEN
*
2
+
3
];
char
name_buff
[
NAME_LEN
*
4
+
3
],
table_buff
[
NAME_LEN
*
2
+
3
];
char
query_buff
[
512
];
char
query_buff
[
512
];
FILE
*
sql_file
=
md_result_file
;
FILE
*
sql_file
=
md_result_file
;
...
...
mysql-test/r/mysqldump.result
View file @
792e46d5
...
@@ -1908,28 +1908,28 @@ a2
...
@@ -1908,28 +1908,28 @@ a2
DROP TRIGGER testref;
DROP TRIGGER testref;
DROP TABLE test1;
DROP TABLE test1;
DROP TABLE test2;
DROP TABLE test2;
CREATE TABLE t1 (id int);
DROP TABLE IF EXISTS t1;
INSERT INTO t1 VALUES(1);
INSERT INTO t1 VALUES(2);
INSERT INTO t1 VALUES(3);
INSERT INTO t1 VALUES(4);
INSERT INTO t1 VALUES(5);
DROP FUNCTION IF EXISTS bug9056_func1;
DROP FUNCTION IF EXISTS bug9056_func1;
CREATE FUNCTION `bug9056_func1`(a INT, b INT) RETURNS int(11)
DROP FUNCTION IF EXISTS bug9056_func2;
RETURN a+b //
DROP PROCEDURE IF EXISTS bug9056_proc1;
DROP PROCEDURE IF EXISTS bug9056_proc2;
CREATE TABLE t1 (id int);
INSERT INTO t1 VALUES(1), (2), (3), (4), (5);
CREATE FUNCTION `bug9056_func1`(a INT, b INT) RETURNS int(11) RETURN a+b //
CREATE PROCEDURE `bug9056_proc1`(IN a INT, IN b INT, OUT c INT)
CREATE PROCEDURE `bug9056_proc1`(IN a INT, IN b INT, OUT c INT)
BEGIN SELECT a+b INTO c; end //
BEGIN SELECT a+b INTO c; end //
DROP FUNCTION IF EXISTS bug9056_func2 //
create function bug9056_func2(f1 char binary) returns char binary
create function bug9056_func2(f1 char binary) returns char binary
begin
begin
set f1= concat( 'hello', f1 );
set f1= concat( 'hello', f1 );
return f1;
return f1;
end //
end //
DROP PROCEDURE IF EXISTS bug9056_proc2 //
CREATE PROCEDURE bug9056_proc2(OUT a INT)
CREATE PROCEDURE bug9056_proc2(OUT a INT)
BEGIN
BEGIN
select sum(id) from t1 into a;
select sum(id) from t1 into a;
END //
END //
set sql_mode='ansi';
create procedure `a'b` () select 1;
set sql_mode='';
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
...
@@ -1954,32 +1954,38 @@ LOCK TABLES `t1` WRITE;
...
@@ -1954,32 +1954,38 @@ LOCK TABLES `t1` WRITE;
INSERT INTO `t1` VALUES (1),(2),(3),(4),(5);
INSERT INTO `t1` VALUES (1),(2),(3),(4),(5);
UNLOCK TABLES;
UNLOCK TABLES;
/*!40000 ALTER TABLE `t1` ENABLE KEYS */;
/*!40000 ALTER TABLE `t1` ENABLE KEYS */;
/*!50003 SET @OLD_SQL_MODE=@@SQL_MODE*/;
DELIMITER //
DELIMITER //
/*!50003 DROP FUNCTION IF EXISTS `bug9056_func1` */ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 DROP FUNCTION IF EXISTS bug9056_func1 */ //
/*!50003 CREATE FUNCTION `bug9056_func1`(a INT, b INT) RETURNS int(11)
/*!50003 CREATE FUNCTION `bug9056_func1`(a INT, b INT) RETURNS int(11)
RETURN a+b */ //
RETURN a+b */ //
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
/*!50003 DROP FUNCTION IF EXISTS `bug9056_func2` */ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 DROP FUNCTION IF EXISTS bug9056_func2 */ //
/*!50003 CREATE FUNCTION `bug9056_func2`(f1 char binary) RETURNS char(1)
/*!50003 CREATE FUNCTION `bug9056_func2`(f1 char binary) RETURNS char(1)
begin
begin
set f1= concat( 'hello', f1 );
set f1= concat( 'hello', f1 );
return f1;
return f1;
end */ //
end */ //
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
/*!50003 DROP PROCEDURE IF EXISTS `a'b` */ //
/*!50003 SET SESSION SQL_MODE="REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,ANSI"*/ //
/*!50003 CREATE PROCEDURE "a'b"()
select 1 */ //
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
/*!50003 DROP PROCEDURE IF EXISTS `bug9056_proc1` */ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 DROP PROCEDURE IF EXISTS bug9056_proc1 */ //
/*!50003 CREATE PROCEDURE `bug9056_proc1`(IN a INT, IN b INT, OUT c INT)
/*!50003 CREATE PROCEDURE `bug9056_proc1`(IN a INT, IN b INT, OUT c INT)
BEGIN SELECT a+b INTO c; end */ //
BEGIN SELECT a+b INTO c; end */ //
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
/*!50003 DROP PROCEDURE IF EXISTS `bug9056_proc2` */ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 SET SESSION SQL_MODE=""*/ //
/*!50003 DROP PROCEDURE IF EXISTS bug9056_proc2 */ //
/*!50003 CREATE PROCEDURE `bug9056_proc2`(OUT a INT)
/*!50003 CREATE PROCEDURE `bug9056_proc2`(OUT a INT)
BEGIN
BEGIN
select sum(id) from t1 into a;
select sum(id) from t1 into a;
END */ //
END */ //
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/ //
DELIMITER ;
DELIMITER ;
/*!50003 SET SESSION SQL_MODE=@OLD_SQL_MODE*/;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
...
@@ -1989,8 +1995,8 @@ DELIMITER ;
...
@@ -1989,8 +1995,8 @@ DELIMITER ;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
DROP
PROCEDURE IF EXISTS
bug9056_func1;
DROP
FUNCTION
bug9056_func1;
DROP
PROCEDURE IF EXISTS
bug9056_func2;
DROP
FUNCTION
bug9056_func2;
DROP PROCEDURE
IF EXISTS
bug9056_proc1;
DROP PROCEDURE bug9056_proc1;
DROP PROCEDURE
IF EXISTS
bug9056_proc2;
DROP PROCEDURE bug9056_proc2;
drop table t1;
drop table t1;
mysql-test/t/mysqldump.test
View file @
792e46d5
...
@@ -810,34 +810,32 @@ DROP TRIGGER testref;
...
@@ -810,34 +810,32 @@ DROP TRIGGER testref;
DROP
TABLE
test1
;
DROP
TABLE
test1
;
DROP
TABLE
test2
;
DROP
TABLE
test2
;
CREATE
TABLE
t1
(
id
int
);
#
INSERT
INTO
t1
VALUES
(
1
);
# BUG#9056 - mysqldump does not dump routines
INSERT
INTO
t1
VALUES
(
2
);
#
INSERT
INTO
t1
VALUES
(
3
);
INSERT
INTO
t1
VALUES
(
4
);
INSERT
INTO
t1
VALUES
(
5
);
--
disable_warnings
--
disable_warnings
DROP
TABLE
IF
EXISTS
t1
;
DROP
FUNCTION
IF
EXISTS
bug9056_func1
;
DROP
FUNCTION
IF
EXISTS
bug9056_func1
;
DELIMITER
//;
DROP
FUNCTION
IF
EXISTS
bug9056_func2
;
DROP
PROCEDURE
IF
EXISTS
bug9056_proc1
;
DROP
PROCEDURE
IF
EXISTS
bug9056_proc2
;
--
enable_warnings
--
enable_warnings
CREATE
FUNCTION
`
bug9056_func1
`(a INT, b INT) RETURNS int(11)
RETURN a+b //
CREATE
TABLE
t1
(
id
int
);
INSERT
INTO
t1
VALUES
(
1
),
(
2
),
(
3
),
(
4
),
(
5
);
DELIMITER
//;
CREATE
FUNCTION
`
bug9056_func1
`(a INT, b INT) RETURNS int(11) RETURN a+b //
CREATE PROCEDURE `
bug9056_proc1
`(IN a INT, IN b INT, OUT c INT)
CREATE PROCEDURE `
bug9056_proc1
`(IN a INT, IN b INT, OUT c INT)
BEGIN SELECT a+b INTO c; end //
BEGIN SELECT a+b INTO c; end //
--
disable_warnings
DROP
FUNCTION
IF
EXISTS
bug9056_func2
//
--
enable_warnings
create function bug9056_func2(f1 char binary) returns char binary
create function bug9056_func2(f1 char binary) returns char binary
begin
begin
set f1= concat( 'hello', f1 );
set f1= concat( 'hello', f1 );
return f1;
return f1;
end //
end //
--
disable_warnings
DROP
PROCEDURE
IF
EXISTS
bug9056_proc2
//
--
enable_warnings
CREATE PROCEDURE bug9056_proc2(OUT a INT)
CREATE PROCEDURE bug9056_proc2(OUT a INT)
BEGIN
BEGIN
select sum(id) from t1 into a;
select sum(id) from t1 into a;
...
@@ -845,14 +843,17 @@ END //
...
@@ -845,14 +843,17 @@ END //
DELIMITER ;//
DELIMITER ;//
set sql_mode='ansi';
create procedure `
a
'b` () select 1; # to fix syntax highlighting :'
)
set
sql_mode
=
''
;
# Dump the DB and ROUTINES
# Dump the DB and ROUTINES
--
exec
$MYSQL_DUMP
--
skip
-
comments
--
routines
--
databases
test
--
exec
$MYSQL_DUMP
--
skip
-
comments
--
routines
--
databases
test
# ok, now blow it all away
# ok, now blow it all away
--
disable_warnings
DROP
FUNCTION
bug9056_func1
;
DROP
PROCEDURE
IF
EXISTS
bug9056_func1
;
DROP
FUNCTION
bug9056_func2
;
DROP
PROCEDURE
IF
EXISTS
bug9056_func2
;
DROP
PROCEDURE
bug9056_proc1
;
DROP
PROCEDURE
IF
EXISTS
bug9056_proc1
;
DROP
PROCEDURE
bug9056_proc2
;
DROP
PROCEDURE
IF
EXISTS
bug9056_proc2
;
drop
table
t1
;
drop
table
t1
;
--
enable
-
warnings
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