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
4f5d1a85
Commit
4f5d1a85
authored
Apr 09, 2013
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
discovery using sql CREATE TABLE statement
parent
ba1b502c
Changes
13
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
343 additions
and
217 deletions
+343
-217
mysql-test/r/alter_table.result
mysql-test/r/alter_table.result
+3
-3
mysql-test/r/merge.result
mysql-test/r/merge.result
+12
-12
mysql-test/r/show_check.result
mysql-test/r/show_check.result
+1
-1
mysql-test/suite/archive/archive.result
mysql-test/suite/archive/archive.result
+1
-1
sql/handler.cc
sql/handler.cc
+4
-0
sql/share/errmsg-utf8.txt
sql/share/errmsg-utf8.txt
+3
-0
sql/sql_table.cc
sql/sql_table.cc
+153
-122
sql/sql_table.h
sql/sql_table.h
+7
-0
sql/table.cc
sql/table.cc
+138
-23
sql/table.h
sql/table.h
+4
-2
sql/unireg.cc
sql/unireg.cc
+8
-39
sql/unireg.h
sql/unireg.h
+7
-11
storage/archive/ha_archive.cc
storage/archive/ha_archive.cc
+2
-3
No files found.
mysql-test/r/alter_table.result
View file @
4f5d1a85
...
...
@@ -978,7 +978,7 @@ SHOW CREATE TABLE `tt+2`;
Table Create Table
tt+2 CREATE TEMPORARY TABLE `tt+2` (
`c1` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
DROP TABLE `tt+1`, `tt+2`;
CREATE TABLE `#sql1` (c1 INT);
CREATE TABLE `@0023sql2` (c1 INT);
...
...
@@ -1015,12 +1015,12 @@ SHOW CREATE TABLE `#sql2`;
Table Create Table
#sql2 CREATE TEMPORARY TABLE `#sql2` (
`c1` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
SHOW CREATE TABLE `@0023sql1`;
Table Create Table
@0023sql1 CREATE TEMPORARY TABLE `@0023sql1` (
`c1` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
DROP TABLE `#sql2`, `@0023sql1`;
DROP TABLE IF EXISTS t1;
DROP TABLE IF EXISTS t2;
...
...
mysql-test/r/merge.result
View file @
4f5d1a85
...
...
@@ -2883,7 +2883,7 @@ Table Create Table
m2 CREATE TEMPORARY TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m2;
c1 c2
111 121
...
...
@@ -2900,7 +2900,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m1;
c1 c2
111 121
...
...
@@ -2989,7 +2989,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT INTO m1 VALUES (511, 521);
SELECT * FROM m1;
c1 c2
...
...
@@ -3040,7 +3040,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
#
CREATE TABLE m2 SELECT * FROM m1;
SHOW CREATE TABLE m2;
...
...
@@ -3092,7 +3092,7 @@ Table Create Table
m2 CREATE TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m2;
c1 c2
111 121
...
...
@@ -3118,7 +3118,7 @@ Table Create Table
m2 CREATE TEMPORARY TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m2;
c1 c2
111 121
...
...
@@ -3288,7 +3288,7 @@ Table Create Table
m2 CREATE TEMPORARY TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m2;
c1 c2
111 121
...
...
@@ -3305,7 +3305,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m1;
c1 c2
111 121
...
...
@@ -3396,7 +3396,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT INTO m1 VALUES (511, 521);
SELECT * FROM m1;
c1 c2
...
...
@@ -3447,7 +3447,7 @@ Table Create Table
m1 CREATE TEMPORARY TABLE `m1` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
CREATE TABLE m2 SELECT * FROM m1;
ERROR HY000: Table 'm2' was not locked with LOCK TABLES
#
...
...
@@ -3492,14 +3492,14 @@ Table Create Table
m2 CREATE TEMPORARY TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
LOCK TABLE m1 WRITE, m2 WRITE;
SHOW CREATE TABLE m2;
Table Create Table
m2 CREATE TEMPORARY TABLE `m2` (
`c1` int(11) DEFAULT NULL,
`c2` int(11) DEFAULT NULL
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`t1`,`t2`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
INSERT_METHOD=LAST UNION=(`t1`,`t2`)
SELECT * FROM m2;
c1 c2
111 121
...
...
mysql-test/r/show_check.result
View file @
4f5d1a85
...
...
@@ -198,7 +198,7 @@ show create table t2;
Table Create Table
t2 CREATE TEMPORARY TABLE `t2` (
`a` int(11) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
drop table t2;
create table t1 (
test_set set( 'val1', 'val2', 'val3' ) not null default '',
...
...
mysql-test/suite/archive/archive.result
View file @
4f5d1a85
...
...
@@ -12846,5 +12846,5 @@ Table Create Table
t1 CREATE TEMPORARY TABLE `t1` (
`a` int(11) DEFAULT NULL,
`b` varchar(10) DEFAULT NULL
) ENGINE=ARCHIVE DEFAULT CHARSET=latin1
) ENGINE=ARCHIVE DEFAULT CHARSET=latin1
DELAY_KEY_WRITE=1
drop table t1;
sql/handler.cc
View file @
4f5d1a85
...
...
@@ -4317,6 +4317,7 @@ static my_bool discover_handlerton(THD *thd, plugin_ref plugin,
handlerton
*
hton
=
plugin_data
(
plugin
,
handlerton
*
);
if
(
hton
->
state
==
SHOW_OPTION_YES
&&
hton
->
discover_table
)
{
share
->
db_plugin
=
plugin
;
int
error
=
hton
->
discover_table
(
hton
,
thd
,
share
);
if
(
error
!=
HA_ERR_NO_SUCH_TABLE
)
{
...
...
@@ -4324,6 +4325,7 @@ static my_bool discover_handlerton(THD *thd, plugin_ref plugin,
{
DBUG_ASSERT
(
share
->
error
);
// MUST be always set for get_cached_table_share to work
my_error
(
ER_GET_ERRNO
,
MYF
(
0
),
error
);
share
->
db_plugin
=
0
;
}
else
share
->
error
=
OPEN_FRM_OK
;
...
...
@@ -4331,6 +4333,7 @@ static my_bool discover_handlerton(THD *thd, plugin_ref plugin,
status_var_increment
(
thd
->
status_var
.
ha_discover_count
);
return
TRUE
;
// abort the search
}
share
->
db_plugin
=
0
;
}
DBUG_ASSERT
(
share
->
error
==
OPEN_FRM_OPEN_ERROR
);
...
...
@@ -4342,6 +4345,7 @@ int ha_discover_table(THD *thd, TABLE_SHARE *share)
DBUG_ENTER
(
"ha_discover_table"
);
DBUG_ASSERT
(
share
->
error
==
OPEN_FRM_OPEN_ERROR
);
// share is not OK yet
DBUG_ASSERT
(
!
share
->
db_plugin
);
if
(
!
plugin_foreach
(
thd
,
discover_handlerton
,
MYSQL_STORAGE_ENGINE_PLUGIN
,
share
))
...
...
sql/share/errmsg-utf8.txt
View file @
4f5d1a85
...
...
@@ -6600,3 +6600,6 @@ ER_SLAVE_STARTED
eng "SLAVE '%.*s' started"
ER_SLAVE_STOPPED
eng "SLAVE '%.*s' stopped"
ER_SQL_DISCOVER_ERROR
eng "Engine %s failed to discover table %`-.192s.%`-.192s with '%s'"
sql/sql_table.cc
View file @
4f5d1a85
This diff is collapsed.
Click to expand it.
sql/sql_table.h
View file @
4f5d1a85
...
...
@@ -25,6 +25,7 @@ struct TABLE_LIST;
class
THD
;
struct
TABLE
;
struct
handlerton
;
class
handler
;
typedef
struct
st_ha_check_opt
HA_CHECK_OPT
;
struct
HA_CREATE_INFO
;
typedef
struct
st_key
KEY
;
...
...
@@ -140,6 +141,12 @@ bool mysql_create_table_no_lock(THD *thd, const char *db,
Alter_info
*
alter_info
,
bool
tmp_table
,
uint
select_field_count
,
bool
*
is_trans
);
handler
*
mysql_create_frm_image
(
THD
*
thd
,
const
char
*
db
,
const
char
*
table_name
,
HA_CREATE_INFO
*
create_info
,
Alter_info
*
alter_info
,
bool
internal_tmp_table
,
uint
select_field_count
,
LEX_CUSTRING
*
frm
);
bool
mysql_prepare_alter_table
(
THD
*
thd
,
TABLE
*
table
,
HA_CREATE_INFO
*
create_info
,
Alter_info
*
alter_info
);
...
...
sql/table.cc
View file @
4f5d1a85
...
...
@@ -693,9 +693,9 @@ enum open_frm_error open_table_def(THD *thd, TABLE_SHARE *share, uint flags)
*/
bool
TABLE_SHARE
::
init_from_binary_frm_image
(
THD
*
thd
,
bool
write
,
const
uchar
*
frm_image
,
size_t
frm_length
)
int
TABLE_SHARE
::
init_from_binary_frm_image
(
THD
*
thd
,
bool
write
,
const
uchar
*
frm_image
,
size_t
frm_length
)
{
TABLE_SHARE
*
share
=
this
;
uint
new_frm_ver
,
field_pack_length
,
new_field_pack_flag
;
...
...
@@ -729,10 +729,11 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
KEY_PART_INFO
*
first_key_part
=
NULL
;
uint
ext_key_parts
=
0
;
uint
first_key_parts
=
0
;
plugin_ref
se_plugin
=
0
;
keyinfo
=
&
first_keyinfo
;
share
->
ext_key_parts
=
0
;
MEM_ROOT
**
root_ptr
,
*
old_root
;
DBUG_ENTER
(
"
open_binary_frm
"
);
DBUG_ENTER
(
"
TABLE_SHARE::init_from_binary_frm_image
"
);
root_ptr
=
my_pthread_getspecific_ptr
(
MEM_ROOT
**
,
THR_MALLOC
);
old_root
=
*
root_ptr
;
...
...
@@ -776,15 +777,13 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
DBUG_PRINT
(
"info"
,
(
"default_part_db_type = %u"
,
frm_image
[
61
]));
#endif
legacy_db_type
=
(
enum
legacy_db_type
)
(
uint
)
frm_image
[
3
];
DBUG_ASSERT
(
share
->
db_plugin
==
NULL
);
/*
if the storage engine is dynamic, no point in resolving it by its
dynamically allocated legacy_db_type. We will resolve it later by name.
*/
if
(
legacy_db_type
>
DB_TYPE_UNKNOWN
&&
legacy_db_type
<
DB_TYPE_FIRST_DYNAMIC
)
share
->
db_plugin
=
ha_lock_engine
(
NULL
,
ha_checktype
(
thd
,
legacy_db_type
,
0
,
0
));
se_plugin
=
ha_lock_engine
(
NULL
,
ha_checktype
(
thd
,
legacy_db_type
,
0
,
0
));
share
->
db_create_options
=
db_create_options
=
uint2korr
(
frm_image
+
30
);
share
->
db_options_in_use
=
share
->
db_create_options
;
share
->
mysql_version
=
uint4korr
(
frm_image
+
51
);
...
...
@@ -1045,7 +1044,7 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
name
.
length
=
str_db_type_length
;
plugin_ref
tmp_plugin
=
ha_resolve_by_name
(
thd
,
&
name
);
if
(
tmp_plugin
!=
NULL
&&
!
plugin_equals
(
tmp_plugin
,
s
hare
->
db
_plugin
))
if
(
tmp_plugin
!=
NULL
&&
!
plugin_equals
(
tmp_plugin
,
s
e
_plugin
))
{
if
(
legacy_db_type
>
DB_TYPE_UNKNOWN
&&
legacy_db_type
<
DB_TYPE_FIRST_DYNAMIC
&&
...
...
@@ -1057,14 +1056,11 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
}
/*
tmp_plugin is locked with a local lock.
we unlock the old value of s
hare->db
_plugin before
we unlock the old value of s
e
_plugin before
replacing it with a globally locked version of tmp_plugin
*/
plugin_unlock
(
NULL
,
share
->
db_plugin
);
share
->
db_plugin
=
my_plugin_lock
(
NULL
,
tmp_plugin
);
DBUG_PRINT
(
"info"
,
(
"setting dbtype to '%.*s' (%d)"
,
str_db_type_length
,
next_chunk
+
2
,
ha_legacy_type
(
share
->
db_type
())));
plugin_unlock
(
NULL
,
se_plugin
);
se_plugin
=
plugin_lock
(
NULL
,
tmp_plugin
);
}
#ifdef WITH_PARTITION_STORAGE_ENGINE
else
if
(
str_db_type_length
==
9
&&
...
...
@@ -1073,7 +1069,7 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
/*
Use partition handler
tmp_plugin is locked with a local lock.
we unlock the old value of s
hare->db
_plugin before
we unlock the old value of s
e
_plugin before
replacing it with a globally locked version of tmp_plugin
*/
/* Check if the partitioning engine is ready */
...
...
@@ -1083,11 +1079,8 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
"--skip-partition"
);
goto
err
;
}
plugin_unlock
(
NULL
,
share
->
db_plugin
);
share
->
db_plugin
=
ha_lock_engine
(
NULL
,
partition_hton
);
DBUG_PRINT
(
"info"
,
(
"setting dbtype to '%.*s' (%d)"
,
str_db_type_length
,
next_chunk
+
2
,
ha_legacy_type
(
share
->
db_type
())));
plugin_unlock
(
NULL
,
se_plugin
);
se_plugin
=
ha_lock_engine
(
NULL
,
partition_hton
);
}
#endif
else
if
(
!
tmp_plugin
)
...
...
@@ -1284,7 +1277,7 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
/* Allocate handler */
if
(
!
(
handler_file
=
get_new_handler
(
share
,
thd
->
mem_root
,
share
->
db_type
(
))))
plugin_data
(
se_plugin
,
handlerton
*
))))
goto
err
;
record
=
share
->
default_values
-
1
;
/* Fieldstart = 1 */
...
...
@@ -1909,6 +1902,8 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
(
void
)
my_hash_check
(
&
share
->
name_hash
);
#endif
DBUG_ASSERT
(
!
share
->
db_plugin
||
plugin_equals
(
share
->
db_plugin
,
se_plugin
));
share
->
db_plugin
=
se_plugin
;
share
->
error
=
OPEN_FRM_OK
;
thd
->
status_var
.
opened_shares
++
;
*
root_ptr
=
old_root
;
...
...
@@ -1918,6 +1913,7 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
share
->
error
=
OPEN_FRM_CORRUPTED
;
share
->
open_errno
=
my_errno
;
delete
handler_file
;
plugin_unlock
(
0
,
se_plugin
);
my_hash_free
(
&
share
->
name_hash
);
if
(
share
->
ha_data_destroy
)
{
...
...
@@ -1936,9 +1932,128 @@ bool TABLE_SHARE::init_from_binary_frm_image(THD *thd, bool write,
open_table_error
(
share
,
OPEN_FRM_CORRUPTED
,
share
->
open_errno
);
*
root_ptr
=
old_root
;
DBUG_RETURN
(
1
);
}
/* open_binary_frm */
DBUG_RETURN
(
HA_ERR_NOT_A_TABLE
);
}
static
bool
sql_unusable_for_discovery
(
THD
*
thd
,
const
char
*
sql
)
{
LEX
*
lex
=
thd
->
lex
;
HA_CREATE_INFO
*
create_info
=
&
lex
->
create_info
;
// ... not CREATE TABLE
if
(
lex
->
sql_command
!=
SQLCOM_CREATE_TABLE
)
return
1
;
// ... create like
if
(
create_info
->
options
&
HA_LEX_CREATE_TABLE_LIKE
)
return
1
;
// ... create select
if
(
lex
->
select_lex
.
item_list
.
elements
)
return
1
;
// ... temporary
if
(
create_info
->
options
&
HA_LEX_CREATE_TMP_TABLE
)
return
1
;
// ... if exists
if
(
create_info
->
options
&
HA_LEX_CREATE_IF_NOT_EXISTS
)
return
1
;
// XXX error out or rather ignore the following:
// ... partitioning
if
(
lex
->
part_info
)
return
1
;
// ... union
if
(
create_info
->
used_fields
&
HA_CREATE_USED_UNION
)
return
1
;
// ... index/data directory
if
(
create_info
->
data_file_name
||
create_info
->
index_file_name
)
return
1
;
// ... engine
if
(
create_info
->
used_fields
&
HA_CREATE_USED_ENGINE
)
return
1
;
return
0
;
}
int
TABLE_SHARE
::
init_from_sql_statement_string
(
THD
*
thd
,
bool
write
,
const
char
*
sql
,
size_t
sql_length
)
{
ulonglong
saved_mode
=
thd
->
variables
.
sql_mode
;
CHARSET_INFO
*
old_cs
=
thd
->
variables
.
character_set_client
;
Parser_state
parser_state
;
bool
error
;
char
*
sql_copy
;
handler
*
file
;
LEX
*
old_lex
;
Query_arena
*
arena
,
backup
;
LEX
tmp_lex
;
LEX_CUSTRING
frm
=
{
0
,
0
};
DBUG_ENTER
(
"TABLE_SHARE::init_from_sql_statement_string"
);
/*
Ouch. Parser may *change* the string it's working on.
Currently (2013-02-26) it is used to permanently disable
conditional comments.
Anyway, let's copy the caller's string...
*/
if
(
!
(
sql_copy
=
thd
->
strmake
(
sql
,
sql_length
)))
DBUG_RETURN
(
HA_ERR_OUT_OF_MEM
);
if
(
parser_state
.
init
(
thd
,
sql_copy
,
sql_length
))
DBUG_RETURN
(
HA_ERR_OUT_OF_MEM
);
thd
->
variables
.
sql_mode
=
MODE_NO_ENGINE_SUBSTITUTION
|
MODE_NO_DIR_IN_CREATE
;
thd
->
variables
.
character_set_client
=
system_charset_info
;
tmp_disable_binlog
(
thd
);
old_lex
=
thd
->
lex
;
thd
->
lex
=
&
tmp_lex
;
arena
=
thd
->
stmt_arena
;
if
(
arena
->
is_conventional
())
arena
=
0
;
else
thd
->
set_n_backup_active_arena
(
arena
,
&
backup
);
lex_start
(
thd
);
if
((
error
=
parse_sql
(
thd
,
&
parser_state
,
NULL
)))
goto
ret
;
if
(
sql_unusable_for_discovery
(
thd
,
sql_copy
))
{
my_error
(
ER_SQL_DISCOVER_ERROR
,
MYF
(
0
),
plugin_name
(
db_plugin
)
->
str
,
db
.
str
,
table_name
.
str
,
sql_copy
);
goto
ret
;
}
thd
->
lex
->
create_info
.
db_type
=
plugin_data
(
db_plugin
,
handlerton
*
);
file
=
mysql_create_frm_image
(
thd
,
db
.
str
,
table_name
.
str
,
&
thd
->
lex
->
create_info
,
&
thd
->
lex
->
alter_info
,
0
,
0
,
&
frm
);
error
|=
file
==
0
;
delete
file
;
if
(
frm
.
str
)
error
=
init_from_binary_frm_image
(
thd
,
write
,
frm
.
str
,
frm
.
length
);
ret:
my_free
(
const_cast
<
uchar
*>
(
frm
.
str
));
lex_end
(
thd
->
lex
);
thd
->
lex
=
old_lex
;
if
(
arena
)
thd
->
restore_active_arena
(
arena
,
&
backup
);
reenable_binlog
(
thd
);
thd
->
variables
.
sql_mode
=
saved_mode
;
thd
->
variables
.
character_set_client
=
old_cs
;
if
(
thd
->
is_error
()
||
error
)
{
thd
->
clear_error
();
my_error
(
ER_NO_SUCH_TABLE
,
MYF
(
0
),
db
.
str
,
table_name
.
str
);
DBUG_RETURN
(
HA_ERR_NOT_A_TABLE
);
}
DBUG_RETURN
(
0
);
}
bool
TABLE_SHARE
::
write_frm_image
(
const
uchar
*
frm
,
size_t
len
)
{
...
...
sql/table.h
View file @
4f5d1a85
...
...
@@ -989,8 +989,10 @@ struct TABLE_SHARE
uint
actual_n_key_parts
(
THD
*
thd
);
LEX_CUSTRING
*
frm_image
;
///< only during CREATE TABLE (@sa ha_create_table)
bool
init_from_binary_frm_image
(
THD
*
thd
,
bool
write
,
const
uchar
*
frm_image
,
size_t
frm_length
);
int
init_from_binary_frm_image
(
THD
*
thd
,
bool
write
,
const
uchar
*
frm_image
,
size_t
frm_length
);
int
init_from_sql_statement_string
(
THD
*
thd
,
bool
write
,
const
char
*
sql
,
size_t
sql_length
);
bool
write_frm_image
(
const
uchar
*
frm_image
,
size_t
frm_length
);
bool
read_frm_image
(
const
uchar
**
frm_image
,
size_t
*
frm_length
);
};
...
...
sql/unireg.cc
View file @
4f5d1a85
...
...
@@ -44,8 +44,6 @@ static uint get_interval_id(uint *,List<Create_field> &, Create_field *);
static
bool
pack_fields
(
uchar
*
,
List
<
Create_field
>
&
,
ulong
);
static
size_t
packed_fields_length
(
List
<
Create_field
>
&
);
static
bool
make_empty_rec
(
THD
*
,
uchar
*
,
uint
,
List
<
Create_field
>
&
,
uint
,
ulong
);
static
LEX_CUSTRING
create_frm_image
(
THD
*
,
const
char
*
,
HA_CREATE_INFO
*
,
List
<
Create_field
>
&
,
uint
,
KEY
*
,
handler
*
);
/*
Create a frm (table definition) file
...
...
@@ -67,27 +65,7 @@ static LEX_CUSTRING create_frm_image(THD *, const char *, HA_CREATE_INFO *,
true error
*/
bool
mysql_create_frm
(
THD
*
thd
,
const
char
*
file_name
,
const
char
*
db
,
const
char
*
table
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_fields
,
uint
keys
,
KEY
*
key_info
,
handler
*
db_file
)
{
DBUG_ENTER
(
"mysql_create_frm"
);
LEX_CUSTRING
frm
=
create_frm_image
(
thd
,
table
,
create_info
,
create_fields
,
keys
,
key_info
,
db_file
);
if
(
!
frm
.
str
)
DBUG_RETURN
(
1
);
int
error
=
writefrm
(
file_name
,
db
,
table
,
!
create_info
->
tmp_table
(),
frm
.
str
,
frm
.
length
);
my_free
(
const_cast
<
uchar
*>
(
frm
.
str
));
DBUG_RETURN
(
error
);
}
LEX_CUSTRING
create_frm_image
(
THD
*
thd
,
const
char
*
table
,
LEX_CUSTRING
build_frm_image
(
THD
*
thd
,
const
char
*
table
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_fields
,
uint
keys
,
KEY
*
key_info
,
handler
*
db_file
)
...
...
@@ -104,7 +82,7 @@ LEX_CUSTRING create_frm_image(THD *thd, const char *table,
int
error
;
uchar
*
frm_ptr
,
*
pos
;
LEX_CUSTRING
frm
=
{
0
,
0
};
DBUG_ENTER
(
"
create
_frm_image"
);
DBUG_ENTER
(
"
build
_frm_image"
);
/* If fixed row records, we need one bit to check for deleted rows */
if
(
!
(
create_info
->
table_options
&
HA_OPTION_PACK_RECORD
))
...
...
@@ -373,37 +351,30 @@ LEX_CUSTRING create_frm_image(THD *thd, const char *table,
1 error
*/
int
rea_create_table
(
THD
*
thd
,
const
char
*
path
,
const
char
*
db
,
const
char
*
table_name
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_fields
,
uint
keys
,
KEY
*
key_info
,
handler
*
file
)
int
rea_create_table
(
THD
*
thd
,
LEX_CUSTRING
*
frm
,
const
char
*
path
,
const
char
*
db
,
const
char
*
table_name
,
HA_CREATE_INFO
*
create_info
,
handler
*
file
)
{
DBUG_ENTER
(
"rea_create_table"
);
LEX_CUSTRING
frm
=
create_frm_image
(
thd
,
table_name
,
create_info
,
create_fields
,
keys
,
key_info
,
file
);
if
(
!
frm
.
str
)
DBUG_RETURN
(
1
);
if
(
thd
->
variables
.
keep_files_on_create
)
create_info
->
options
|=
HA_CREATE_KEEP_FILES
;
if
(
create_info
->
frm_only
)
{
if
(
writefrm
(
path
,
db
,
table_name
,
1
,
frm
.
str
,
frm
.
length
))
if
(
writefrm
(
path
,
db
,
table_name
,
1
,
frm
->
str
,
frm
->
length
))
goto
err_handler
;
}
else
{
// TODO don't write frm for temp tables
if
(
create_info
->
tmp_table
()
&&
writefrm
(
path
,
db
,
table_name
,
0
,
frm
.
str
,
frm
.
length
))
writefrm
(
path
,
db
,
table_name
,
0
,
frm
->
str
,
frm
->
length
))
goto
err_handler
;
if
(
file
->
ha_create_partitioning_metadata
(
path
,
NULL
,
CHF_CREATE_FLAG
,
create_info
)
||
ha_create_table
(
thd
,
path
,
db
,
table_name
,
create_info
,
&
frm
))
ha_create_table
(
thd
,
path
,
db
,
table_name
,
create_info
,
frm
))
{
file
->
ha_create_partitioning_metadata
(
path
,
NULL
,
CHF_DELETE_FLAG
,
create_info
);
...
...
@@ -411,14 +382,12 @@ int rea_create_table(THD *thd, const char *path,
}
}
my_free
(
const_cast
<
uchar
*>
(
frm
.
str
));
DBUG_RETURN
(
0
);
err_handler:
char
frm_name
[
FN_REFLEN
];
strxmov
(
frm_name
,
path
,
reg_ext
,
NullS
);
mysql_file_delete
(
key_file_frm
,
frm_name
,
MYF
(
0
));
my_free
(
const_cast
<
uchar
*>
(
frm
.
str
));
DBUG_RETURN
(
1
);
}
/* rea_create_table */
...
...
sql/unireg.h
View file @
4f5d1a85
...
...
@@ -167,17 +167,13 @@
#include "sql_list.h"
/* List<> */
#include "field.h"
/* Create_field */
bool
mysql_create_frm
(
THD
*
thd
,
const
char
*
file_name
,
const
char
*
db
,
const
char
*
table
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_field
,
uint
key_count
,
KEY
*
key_info
,
handler
*
db_type
);
int
rea_create_table
(
THD
*
thd
,
const
char
*
path
,
const
char
*
db
,
const
char
*
table_name
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_field
,
uint
key_count
,
KEY
*
key_info
,
handler
*
file
);
int
rea_create_table
(
THD
*
thd
,
LEX_CUSTRING
*
frm
,
const
char
*
path
,
const
char
*
db
,
const
char
*
table_name
,
HA_CREATE_INFO
*
create_info
,
handler
*
file
);
LEX_CUSTRING
build_frm_image
(
THD
*
thd
,
const
char
*
table
,
HA_CREATE_INFO
*
create_info
,
List
<
Create_field
>
&
create_fields
,
uint
keys
,
KEY
*
key_info
,
handler
*
db_file
);
#define FRM_HEADER_SIZE 64
#define FRM_FORMINFO_SIZE 288
...
...
storage/archive/ha_archive.cc
View file @
4f5d1a85
...
...
@@ -302,9 +302,8 @@ int archive_discover(handlerton *hton, THD* thd, TABLE_SHARE *share)
azclose
(
&
frm_stream
);
if
(
!
share
->
init_from_binary_frm_image
(
thd
,
1
,
frm_ptr
,
frm_stream
.
frm_length
))
my_errno
=
0
;
my_errno
=
share
->
init_from_binary_frm_image
(
thd
,
1
,
frm_ptr
,
frm_stream
.
frm_length
);
ret:
my_free
(
frm_ptr
);
DBUG_RETURN
(
my_errno
);
...
...
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