Commit cbc851c6 authored by unknown's avatar unknown

Merge akeremidarski@work.mysql.com:/home/bk/mysql

into geopard.(none):/storage/bk/mysql-3.23

parents 7bf4febc de6eea8b
...@@ -1000,8 +1000,8 @@ row_update_cascade_for_mysql( ...@@ -1000,8 +1000,8 @@ row_update_cascade_for_mysql(
or set null operation */ or set null operation */
dict_table_t* table) /* in: table where we do the operation */ dict_table_t* table) /* in: table where we do the operation */
{ {
ulint err; ulint err;
trx_t* trx; trx_t* trx;
trx = thr_get_trx(thr); trx = thr_get_trx(thr);
run_again: run_again:
...@@ -1012,11 +1012,26 @@ row_update_cascade_for_mysql( ...@@ -1012,11 +1012,26 @@ row_update_cascade_for_mysql(
err = trx->error_state; err = trx->error_state;
/* Note that the cascade node is a subnode of another InnoDB
query graph node. We do a normal lock wait in this node, but
all errors are handled by the parent node. */
if (err == DB_LOCK_WAIT) { if (err == DB_LOCK_WAIT) {
que_thr_stop_for_mysql(thr); /* Handle lock wait here */
row_mysql_handle_errors(&err, trx, thr, NULL); que_thr_stop_for_mysql(thr);
srv_suspend_mysql_thread(thr);
/* Note that a lock wait may also end in a lock wait timeout */
if (trx->error_state != DB_SUCCESS) {
return(trx->error_state);
}
/* Retry operation after a normal lock wait */
goto run_again; goto run_again;
} }
......
...@@ -4970,6 +4970,8 @@ end_write_group(JOIN *join, JOIN_TAB *join_tab __attribute__((unused)), ...@@ -4970,6 +4970,8 @@ end_write_group(JOIN *join, JOIN_TAB *join_tab __attribute__((unused)),
} }
else else
{ {
if (end_of_records)
DBUG_RETURN(0);
join->first_record=1; join->first_record=1;
VOID(test_if_group_changed(join->group_fields)); VOID(test_if_group_changed(join->group_fields));
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment