summaryrefslogtreecommitdiff
path: root/sql/sql_table.cc
diff options
context:
space:
mode:
authorunknown <sasha@mysql.sashanet.com>2000-08-07 15:28:56 -0600
committerunknown <sasha@mysql.sashanet.com>2000-08-07 15:28:56 -0600
commit1d598de95500eafa40ab696abb9e9487ac97fee2 (patch)
treeee6536e9eb1ae43c32de241c459d020cce01ff4e /sql/sql_table.cc
parent62d9bd5da37fa05f0d681a37c1ceb057e82c0f74 (diff)
downloadmariadb-git-1d598de95500eafa40ab696abb9e9487ac97fee2.tar.gz
fixed coredump in UDF
added Monty's patch for alter table and LAST_INSERT_ID() added a test case for replication of ALTER TABLE on a table with auto_increment sql/item_func.cc: fixed a coredump in UDF sql/sql_table.cc: fixed LAST_INSERT_ID() problem after ALTER TABLE on a table with auto_increment
Diffstat (limited to 'sql/sql_table.cc')
-rw-r--r--sql/sql_table.cc15
1 files changed, 9 insertions, 6 deletions
diff --git a/sql/sql_table.cc b/sql/sql_table.cc
index ed63b12ceb1..6e39a1a962b 100644
--- a/sql/sql_table.cc
+++ b/sql/sql_table.cc
@@ -32,7 +32,7 @@ static char *make_unique_key_name(const char *field_name,KEY *start,KEY *end);
static int copy_data_between_tables(TABLE *from,TABLE *to,
List<create_field> &create,
enum enum_duplicates handle_duplicates,
- ulong *copied,ulong *deleted);
+ ha_rows *copied,ha_rows *deleted);
/*****************************************************************************
** Remove all possbile tables and give a compact errormessage for all
@@ -992,7 +992,8 @@ int mysql_alter_table(THD *thd,char *new_db, char *new_name,
char tmp_name[80],old_name[32],new_name_buff[FN_REFLEN],
*table_name,*db;
bool use_timestamp=0;
- ulong copied,deleted;
+ ha_rows copied,deleted;
+ ulonglong next_insert_id;
uint save_time_stamp,db_create_options;
enum db_type old_db_type,new_db_type;
DBUG_ENTER("mysql_alter_table");
@@ -1333,11 +1334,13 @@ int mysql_alter_table(THD *thd,char *new_db, char *new_name,
if (use_timestamp)
new_table->time_stamp=0;
new_table->next_number_field=new_table->found_next_number_field;
- thd->count_cuted_fields=1; /* calc cuted fields */
+ thd->count_cuted_fields=1; // calc cuted fields
thd->cuted_fields=0L;
thd->proc_info="copy to tmp table";
+ next_insert_id=thd->next_insert_id; // Remember for loggin
error=copy_data_between_tables(table,new_table,create_list,handle_duplicates,
&copied,&deleted);
+ thd->last_insert_id=next_insert_id; // Needed for correct log
thd->count_cuted_fields=0; /* Don`t calc cuted fields */
new_table->time_stamp=save_time_stamp;
@@ -1474,8 +1477,8 @@ int mysql_alter_table(THD *thd,char *new_db, char *new_name,
VOID(pthread_mutex_unlock(&LOCK_open));
end_temporary:
- sprintf(tmp_name,ER(ER_INSERT_INFO),copied+deleted,deleted,
- thd->cuted_fields);
+ sprintf(tmp_name,ER(ER_INSERT_INFO),(ulong) (copied+deleted),
+ (ulong) deleted, thd->cuted_fields);
send_ok(&thd->net,copied+deleted,0L,tmp_name);
thd->some_tables_deleted=0;
DBUG_RETURN(0);
@@ -1488,7 +1491,7 @@ end_temporary:
static int
copy_data_between_tables(TABLE *from,TABLE *to,List<create_field> &create,
enum enum_duplicates handle_duplicates,
- ulong *copied,ulong *deleted)
+ ha_rows *copied,ha_rows *deleted)
{
int error;
Copy_field *copy,*copy_end;