mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
merge
This commit is contained in:
@ -137,7 +137,7 @@ a t
|
|||||||
explain select count(*) from t1 as tt1, (select * from t1) as tt2;
|
explain select count(*) from t1 as tt1, (select * from t1) as tt2;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Select tables optimized away
|
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Select tables optimized away
|
||||||
2 DERIVED tt1 index NULL a 4 NULL 10000 Using index
|
2 DERIVED tt1 ALL NULL NULL NULL NULL 10000
|
||||||
drop table t1;
|
drop table t1;
|
||||||
SELECT * FROM (SELECT (SELECT * FROM (SELECT 1 as a) as a )) as b;
|
SELECT * FROM (SELECT (SELECT * FROM (SELECT 1 as a) as a )) as b;
|
||||||
(SELECT * FROM (SELECT 1 as a) as a )
|
(SELECT * FROM (SELECT 1 as a) as a )
|
||||||
|
@ -1322,10 +1322,10 @@ SELECT t2.id, t1.label FROM t2 INNER JOIN
|
|||||||
(SELECT t1.id_object as id_object FROM t1 WHERE t1.label LIKE '%test%') AS lbl
|
(SELECT t1.id_object as id_object FROM t1 WHERE t1.label LIKE '%test%') AS lbl
|
||||||
ON (t2.id = lbl.id_object) INNER JOIN t1 ON (t2.id = t1.id_object);
|
ON (t2.id = lbl.id_object) INNER JOIN t1 ON (t2.id = t1.id_object);
|
||||||
id label
|
id label
|
||||||
3382 Fournisseur Test
|
3382 Test
|
||||||
102 Fournisseur Test
|
102 Le Pekin (Test)
|
||||||
1794 Fournisseur Test
|
1794 Test de resto
|
||||||
1822 Fournisseur Test
|
1822 Test 3
|
||||||
3524 Fournisseur Test
|
3524 Societe Test
|
||||||
3525 Fournisseur Test
|
3525 Fournisseur Test
|
||||||
drop table t1,t2;
|
drop table t1,t2;
|
||||||
|
@ -328,3 +328,16 @@ id select_type table type possible_keys key key_len ref rows Extra
|
|||||||
1 PRIMARY t1 const PRIMARY PRIMARY 4 const 1
|
1 PRIMARY t1 const PRIMARY PRIMARY 4 const 1
|
||||||
2 UNION t1 ref b b 5 const 1 Using where
|
2 UNION t1 ref b b 5 const 1 Using where
|
||||||
drop table t1,t2;
|
drop table t1,t2;
|
||||||
|
create table t1 ( id int not null auto_increment, primary key (id) ,user_name text );
|
||||||
|
create table t2 ( id int not null auto_increment, primary key (id) ,group_name text );
|
||||||
|
create table t3 ( id int not null auto_increment, primary key (id) ,user_id int ,index user_idx (user_id) ,foreign key (user_id) references users(id) ,group_id int ,index group_idx (group_id) ,foreign key (group_id) references groups(id) );
|
||||||
|
insert into t1 (user_name) values ('Tester');
|
||||||
|
insert into t2 (group_name) values ('Group A');
|
||||||
|
insert into t2 (group_name) values ('Group B');
|
||||||
|
insert into t3 (user_id, group_id) values (1,1);
|
||||||
|
select 1 'is_in_group', a.user_name, c.group_name, b.id from t1 a, t3 b, t2 c where a.id = b.user_id and b.group_id = c.id UNION select 0 'is_in_group', a.user_name, c.group_name, null from t1 a, t2 c;
|
||||||
|
is_in_group user_name group_name id
|
||||||
|
1 Tester Group A 1
|
||||||
|
0 Tester Group A NULL
|
||||||
|
0 Tester Group B NULL
|
||||||
|
drop table t1, t2, t3;
|
||||||
|
@ -209,3 +209,12 @@ explain (select * from t1 where a=1) union (select * from t2 where a=1);
|
|||||||
explain (select * from t1 where a=1 and b=10) union (select t1.a,t2.a from t1,t2 where t1.a=t2.a);
|
explain (select * from t1 where a=1 and b=10) union (select t1.a,t2.a from t1,t2 where t1.a=t2.a);
|
||||||
explain (select * from t1 where a=1) union (select * from t1 where b=1);
|
explain (select * from t1 where a=1) union (select * from t1 where b=1);
|
||||||
drop table t1,t2;
|
drop table t1,t2;
|
||||||
|
create table t1 ( id int not null auto_increment, primary key (id) ,user_name text );
|
||||||
|
create table t2 ( id int not null auto_increment, primary key (id) ,group_name text );
|
||||||
|
create table t3 ( id int not null auto_increment, primary key (id) ,user_id int ,index user_idx (user_id) ,foreign key (user_id) references users(id) ,group_id int ,index group_idx (group_id) ,foreign key (group_id) references groups(id) );
|
||||||
|
insert into t1 (user_name) values ('Tester');
|
||||||
|
insert into t2 (group_name) values ('Group A');
|
||||||
|
insert into t2 (group_name) values ('Group B');
|
||||||
|
insert into t3 (user_id, group_id) values (1,1);
|
||||||
|
select 1 'is_in_group', a.user_name, c.group_name, b.id from t1 a, t3 b, t2 c where a.id = b.user_id and b.group_id = c.id UNION select 0 'is_in_group', a.user_name, c.group_name, null from t1 a, t2 c;
|
||||||
|
drop table t1, t2, t3;
|
||||||
|
@ -767,12 +767,20 @@ int ha_myisam::preload_keys(THD* thd, HA_CHECK_OPT *check_opt)
|
|||||||
void ha_myisam::deactivate_non_unique_index(ha_rows rows)
|
void ha_myisam::deactivate_non_unique_index(ha_rows rows)
|
||||||
{
|
{
|
||||||
MYISAM_SHARE* share = file->s;
|
MYISAM_SHARE* share = file->s;
|
||||||
|
bool do_warning=0;
|
||||||
if (share->state.key_map == ((ulonglong) 1L << share->base.keys)-1)
|
if (share->state.key_map == ((ulonglong) 1L << share->base.keys)-1)
|
||||||
{
|
{
|
||||||
if (!(specialflag & SPECIAL_SAFE_MODE))
|
if (!(specialflag & SPECIAL_SAFE_MODE))
|
||||||
{
|
{
|
||||||
if (rows == HA_POS_ERROR)
|
if (rows == HA_POS_ERROR)
|
||||||
|
{
|
||||||
|
uint orig_update= file->update;
|
||||||
|
file->update ^= HA_STATE_CHANGED;
|
||||||
|
uint check_update= file->update;
|
||||||
mi_extra(file, HA_EXTRA_NO_KEYS, 0);
|
mi_extra(file, HA_EXTRA_NO_KEYS, 0);
|
||||||
|
do_warning= (file->update == check_update) && file->state->records;
|
||||||
|
file->update= orig_update;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@ -797,6 +805,10 @@ void ha_myisam::deactivate_non_unique_index(ha_rows rows)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
enable_activate_all_index=0;
|
enable_activate_all_index=0;
|
||||||
|
if (do_warning)
|
||||||
|
push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
|
ER_ILLEGAL_HA,
|
||||||
|
ER(ER_ILLEGAL_HA), table->table_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -787,6 +787,7 @@ TABLE *open_table(THD *thd,const char *db,const char *table_name,
|
|||||||
DBUG_RETURN(0);
|
DBUG_RETURN(0);
|
||||||
}
|
}
|
||||||
table->query_id=thd->query_id;
|
table->query_id=thd->query_id;
|
||||||
|
table->clear_query_id=1;
|
||||||
thd->tmp_table_used= 1;
|
thd->tmp_table_used= 1;
|
||||||
goto reset;
|
goto reset;
|
||||||
}
|
}
|
||||||
@ -2048,8 +2049,9 @@ bool setup_tables(TABLE_LIST *tables)
|
|||||||
table->keys_in_use_for_query &= ~map;
|
table->keys_in_use_for_query &= ~map;
|
||||||
}
|
}
|
||||||
table->used_keys &= table->keys_in_use_for_query;
|
table->used_keys &= table->keys_in_use_for_query;
|
||||||
if (table_list->shared)
|
if (table_list->shared || table->clear_query_id)
|
||||||
{
|
{
|
||||||
|
table->clear_query_id= 0;
|
||||||
/* Clear query_id that may have been set by previous select */
|
/* Clear query_id that may have been set by previous select */
|
||||||
for (Field **ptr=table->field ; *ptr ; ptr++)
|
for (Field **ptr=table->field ; *ptr ; ptr++)
|
||||||
(*ptr)->query_id=0;
|
(*ptr)->query_id=0;
|
||||||
|
@ -123,6 +123,16 @@ int mysql_derived(THD *thd, LEX *lex, SELECT_LEX_UNIT *unit,
|
|||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
This is done in order to redo all field optimisations when any of the
|
||||||
|
involved tables is used in the outer query
|
||||||
|
*/
|
||||||
|
if (tables)
|
||||||
|
{
|
||||||
|
for (TABLE_LIST *cursor= tables; cursor; cursor= cursor->next)
|
||||||
|
cursor->table->clear_query_id= 1;
|
||||||
|
}
|
||||||
|
|
||||||
item_list= select_cursor->item_list;
|
item_list= select_cursor->item_list;
|
||||||
select_cursor->with_wild= 0;
|
select_cursor->with_wild= 0;
|
||||||
if (setup_ref_array(thd, &select_cursor->ref_pointer_array,
|
if (setup_ref_array(thd, &select_cursor->ref_pointer_array,
|
||||||
|
@ -1858,10 +1858,19 @@ int mysql_alter_table(THD *thd,char *new_db, char *new_name,
|
|||||||
/* COND_refresh will be signaled in close_thread_tables() */
|
/* COND_refresh will be signaled in close_thread_tables() */
|
||||||
break;
|
break;
|
||||||
case DISABLE:
|
case DISABLE:
|
||||||
|
if (table->db_type == DB_TYPE_MYISAM)
|
||||||
|
{
|
||||||
VOID(pthread_mutex_lock(&LOCK_open));
|
VOID(pthread_mutex_lock(&LOCK_open));
|
||||||
wait_while_table_is_used(thd, table);
|
wait_while_table_is_used(thd, table);
|
||||||
VOID(pthread_mutex_unlock(&LOCK_open));
|
VOID(pthread_mutex_unlock(&LOCK_open));
|
||||||
table->file->deactivate_non_unique_index(HA_POS_ERROR);
|
table->file->deactivate_non_unique_index(HA_POS_ERROR);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN,
|
||||||
|
ER_ILLEGAL_HA,
|
||||||
|
ER(ER_ILLEGAL_HA), table->table_name);
|
||||||
|
break;
|
||||||
|
|
||||||
/* COND_refresh will be signaled in close_thread_tables() */
|
/* COND_refresh will be signaled in close_thread_tables() */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -136,7 +136,7 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
|
|||||||
found_rows_for_union= first_select()->options & OPTION_FOUND_ROWS &&
|
found_rows_for_union= first_select()->options & OPTION_FOUND_ROWS &&
|
||||||
global_parameters->select_limit;
|
global_parameters->select_limit;
|
||||||
if (found_rows_for_union)
|
if (found_rows_for_union)
|
||||||
first_select()->options ^= OPTION_FOUND_ROWS;
|
first_select()->options&= ~OPTION_FOUND_ROWS;
|
||||||
}
|
}
|
||||||
if (t_and_f)
|
if (t_and_f)
|
||||||
{
|
{
|
||||||
@ -154,8 +154,6 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
|
|||||||
goto err;
|
goto err;
|
||||||
List_iterator<Item> it(select_cursor->item_list);
|
List_iterator<Item> it(select_cursor->item_list);
|
||||||
Item *item;
|
Item *item;
|
||||||
while((item=it++))
|
|
||||||
item->maybe_null=1;
|
|
||||||
item_list= select_cursor->item_list;
|
item_list= select_cursor->item_list;
|
||||||
select_cursor->with_wild= 0;
|
select_cursor->with_wild= 0;
|
||||||
if (setup_ref_array(thd, &select_cursor->ref_pointer_array,
|
if (setup_ref_array(thd, &select_cursor->ref_pointer_array,
|
||||||
@ -167,6 +165,12 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
|
|||||||
item_list, 0, 0, 1))
|
item_list, 0, 0, 1))
|
||||||
goto err;
|
goto err;
|
||||||
t_and_f= 1;
|
t_and_f= 1;
|
||||||
|
while((item=it++))
|
||||||
|
{
|
||||||
|
item->maybe_null=1;
|
||||||
|
if (item->type() == Item::FIELD_ITEM)
|
||||||
|
((class Item_field *)item)->field->table->maybe_null=1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tmp_table_param.field_count=item_list.elements;
|
tmp_table_param.field_count=item_list.elements;
|
||||||
@ -250,7 +254,6 @@ err:
|
|||||||
|
|
||||||
int st_select_lex_unit::exec()
|
int st_select_lex_unit::exec()
|
||||||
{
|
{
|
||||||
int do_print_slow= 0;
|
|
||||||
SELECT_LEX_NODE *lex_select_save= thd->lex.current_select;
|
SELECT_LEX_NODE *lex_select_save= thd->lex.current_select;
|
||||||
SELECT_LEX *select_cursor=first_select_in_union();
|
SELECT_LEX *select_cursor=first_select_in_union();
|
||||||
DBUG_ENTER("st_select_lex_unit::exec");
|
DBUG_ENTER("st_select_lex_unit::exec");
|
||||||
@ -318,7 +321,6 @@ int st_select_lex_unit::exec()
|
|||||||
thd->lex.current_select= lex_select_save;
|
thd->lex.current_select= lex_select_save;
|
||||||
DBUG_RETURN(res);
|
DBUG_RETURN(res);
|
||||||
}
|
}
|
||||||
do_print_slow|= select_cursor->options;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
optimized= 1;
|
optimized= 1;
|
||||||
@ -361,12 +363,6 @@ int st_select_lex_unit::exec()
|
|||||||
Mark for slow query log if any of the union parts didn't use
|
Mark for slow query log if any of the union parts didn't use
|
||||||
indexes efficiently
|
indexes efficiently
|
||||||
*/
|
*/
|
||||||
select_cursor->options= ((select_cursor->options &
|
|
||||||
~(QUERY_NO_INDEX_USED |
|
|
||||||
QUERY_NO_GOOD_INDEX_USED)) |
|
|
||||||
do_print_slow &
|
|
||||||
(QUERY_NO_INDEX_USED |
|
|
||||||
QUERY_NO_GOOD_INDEX_USED));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
thd->lex.current_select= lex_select_save;
|
thd->lex.current_select= lex_select_save;
|
||||||
|
@ -116,6 +116,7 @@ struct st_table {
|
|||||||
my_bool crashed;
|
my_bool crashed;
|
||||||
my_bool is_view;
|
my_bool is_view;
|
||||||
my_bool no_keyread;
|
my_bool no_keyread;
|
||||||
|
my_bool clear_query_id; /* To reset query_id for tables and cols */
|
||||||
my_bool auto_increment_field_not_null;
|
my_bool auto_increment_field_not_null;
|
||||||
Field *next_number_field, /* Set if next_number is activated */
|
Field *next_number_field, /* Set if next_number is activated */
|
||||||
*found_next_number_field, /* Set on open */
|
*found_next_number_field, /* Set on open */
|
||||||
|
Reference in New Issue
Block a user