diff options
author | unknown <bell@sanja.is.com.ua> | 2002-11-25 21:27:14 +0200 |
---|---|---|
committer | unknown <bell@sanja.is.com.ua> | 2002-11-25 21:27:14 +0200 |
commit | 30d1b1436162b00fdbd9af8593cab17b2a40a296 (patch) | |
tree | f7de0958810c8e567d83564ff9a09bbaf6b694ac /sql/sql_delete.cc | |
parent | 52f18046c496e021a36692cb9ed3544def87584e (diff) | |
download | mariadb-git-30d1b1436162b00fdbd9af8593cab17b2a40a296.tar.gz |
subselet in delete (SCRUM)
mysql-test/r/subselect.result:
subselects in delete test
mysql-test/t/subselect.test:
subselects in delete test
sql/sql_delete.cc:
subselet in delete
Diffstat (limited to 'sql/sql_delete.cc')
-rw-r--r-- | sql/sql_delete.cc | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/sql/sql_delete.cc b/sql/sql_delete.cc index 16d6b6d4631..5b97b2f7750 100644 --- a/sql/sql_delete.cc +++ b/sql/sql_delete.cc @@ -37,14 +37,18 @@ int mysql_delete(THD *thd, TABLE_LIST *table_list, COND *conds, ORDER *order, bool using_limit=limit != HA_POS_ERROR; bool transactional_table, log_delayed, safe_update, const_cond; ha_rows deleted; + TABLE_LIST *delete_table_list= (TABLE_LIST*) + thd->lex.select_lex.table_list.first; DBUG_ENTER("mysql_delete"); - if (!(table = open_ltable(thd, table_list, table_list->lock_type))) + if ((open_and_lock_tables(thd, table_list))) DBUG_RETURN(-1); + fix_tables_pointers(&thd->lex.select_lex); + table= table_list->table; table->file->info(HA_STATUS_VARIABLE | HA_STATUS_NO_LOCK); thd->proc_info="init"; table->map=1; - if (setup_conds(thd,table_list,&conds) || + if (setup_conds(thd, delete_table_list, &conds) || setup_ftfuncs(&thd->lex.select_lex)) DBUG_RETURN(-1); |