mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
upmerge to bug#14548159
This commit is contained in:
@ -24,6 +24,7 @@
|
||||
#include "sql_acl.h" // DROP_ACL
|
||||
#include "sql_parse.h" // check_one_table_access()
|
||||
#include "sql_truncate.h"
|
||||
#include "sql_show.h" //append_identifier()
|
||||
|
||||
|
||||
/**
|
||||
@ -43,9 +44,8 @@ static bool fk_info_append_fields(String *str, List<LEX_STRING> *fields)
|
||||
|
||||
while ((field= it++))
|
||||
{
|
||||
res|= str->append("`");
|
||||
res|= str->append(field);
|
||||
res|= str->append("`, ");
|
||||
append_identifier(NULL, str, field->str, field->length);
|
||||
res|= str->append(", ");
|
||||
}
|
||||
|
||||
str->chop();
|
||||
@ -76,19 +76,23 @@ static const char *fk_info_str(THD *thd, FOREIGN_KEY_INFO *fk_info)
|
||||
`db`.`tbl`, CONSTRAINT `id` FOREIGN KEY (`fk`) REFERENCES `db`.`tbl` (`fk`)
|
||||
*/
|
||||
|
||||
res|= str.append('`');
|
||||
res|= str.append(fk_info->foreign_db);
|
||||
res|= str.append("`.`");
|
||||
res|= str.append(fk_info->foreign_table);
|
||||
res|= str.append("`, CONSTRAINT `");
|
||||
res|= str.append(fk_info->foreign_id);
|
||||
res|= str.append("` FOREIGN KEY (");
|
||||
append_identifier(NULL, &str, fk_info->foreign_db->str,
|
||||
fk_info->foreign_db->length);
|
||||
res|= str.append(".");
|
||||
append_identifier(NULL, &str, fk_info->foreign_table->str,
|
||||
fk_info->foreign_table->length);
|
||||
res|= str.append(", CONSTRAINT ");
|
||||
append_identifier(NULL, &str, fk_info->foreign_id->str,
|
||||
fk_info->foreign_id->length);
|
||||
res|= str.append(" FOREIGN KEY (");
|
||||
res|= fk_info_append_fields(&str, &fk_info->foreign_fields);
|
||||
res|= str.append(") REFERENCES `");
|
||||
res|= str.append(fk_info->referenced_db);
|
||||
res|= str.append("`.`");
|
||||
res|= str.append(fk_info->referenced_table);
|
||||
res|= str.append("` (");
|
||||
res|= str.append(") REFERENCES ");
|
||||
append_identifier(NULL, &str, fk_info->referenced_db->str,
|
||||
fk_info->referenced_db->length);
|
||||
res|= str.append(".");
|
||||
append_identifier(NULL, &str, fk_info->referenced_table->str,
|
||||
fk_info->referenced_table->length);
|
||||
res|= str.append(" (");
|
||||
res|= fk_info_append_fields(&str, &fk_info->referenced_fields);
|
||||
res|= str.append(')');
|
||||
|
||||
|
Reference in New Issue
Block a user