2001-02-17 14:19:19 +02:00
|
|
|
/******************************************************
|
|
|
|
Cursor read
|
|
|
|
|
|
|
|
(c) 1997 Innobase Oy
|
|
|
|
|
|
|
|
Created 2/16/1997 Heikki Tuuri
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#ifndef read0read_h
|
|
|
|
#define read0read_h
|
|
|
|
|
|
|
|
#include "univ.i"
|
|
|
|
|
|
|
|
|
|
|
|
#include "ut0byte.h"
|
|
|
|
#include "ut0lst.h"
|
|
|
|
#include "trx0trx.h"
|
|
|
|
#include "read0types.h"
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Opens a read view where exactly the transactions serialized before this
|
|
|
|
point in time are seen in the view. */
|
|
|
|
|
|
|
|
read_view_t*
|
|
|
|
read_view_open_now(
|
|
|
|
/*===============*/
|
|
|
|
/* out, own: read view struct */
|
|
|
|
trx_t* cr_trx, /* in: creating transaction, or NULL */
|
|
|
|
mem_heap_t* heap); /* in: memory heap from which allocated */
|
|
|
|
/*************************************************************************
|
|
|
|
Makes a copy of the oldest existing read view, or opens a new. The view
|
|
|
|
must be closed with ..._close. */
|
|
|
|
|
|
|
|
read_view_t*
|
|
|
|
read_view_oldest_copy_or_open_new(
|
|
|
|
/*==============================*/
|
|
|
|
/* out, own: read view struct */
|
|
|
|
trx_t* cr_trx, /* in: creating transaction, or NULL */
|
|
|
|
mem_heap_t* heap); /* in: memory heap from which allocated */
|
|
|
|
/*************************************************************************
|
|
|
|
Closes a read view. */
|
|
|
|
|
|
|
|
void
|
|
|
|
read_view_close(
|
|
|
|
/*============*/
|
|
|
|
read_view_t* view); /* in: read view */
|
|
|
|
/*************************************************************************
|
Many files:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
mysqld.cc:
Change MySQL default isolation level to REPEATABLE READ; note that InnoDB has always had that default, and BDB and MyISAM always run at SERIALIZABLE level anyway
sql/mysqld.cc:
Change MySQL default isolation level to REPEATABLE READ; note that InnoDB has always had that default, and BDB and MyISAM always run at SERIALIZABLE level anyway
sql/ha_innodb.cc:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
sql/ha_innodb.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/buf0buf.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/dict0dict.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/fil0fil.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/lock0lock.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/os0file.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/os0proc.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/os0thread.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/page0cur.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/page0page.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/read0read.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/rem0rec.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/srv0srv.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/sync0rw.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/sync0sync.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/trx0purge.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/trx0trx.h:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/include/rem0rec.ic:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/btr/btr0btr.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/btr/btr0cur.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/btr/btr0pcur.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/buf/buf0buf.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/buf/buf0flu.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/dict/dict0dict.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/fil/fil0fil.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/fsp/fsp0fsp.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/ibuf/ibuf0ibuf.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/lock/lock0lock.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/mem/mem0dbg.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/os/os0file.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/os/os0proc.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/page/page0cur.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/page/page0page.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/pars/lexyy.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/pars/pars0grm.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/read/read0read.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0ins.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0mysql.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0purge.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0sel.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0uins.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0undo.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/row/row0upd.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/srv/srv0srv.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/srv/srv0start.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/sync/sync0rw.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/sync/sync0sync.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/trx/trx0purge.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
innobase/trx/trx0trx.c:
Merge InnoDB-4.0.5: new isolation levels READ COMMITTED and READ UNCOMMITTED now supported, selective deadlock resolution
2002-10-29 23:16:46 +02:00
|
|
|
Closes a consistent read view for MySQL. This function is called at an SQL
|
|
|
|
statement end if the trx isolation level is <= TRX_ISO_READ_COMMITTED. */
|
|
|
|
|
|
|
|
void
|
|
|
|
read_view_close_for_mysql(
|
|
|
|
/*======================*/
|
|
|
|
trx_t* trx); /* in: trx which has a read view */
|
|
|
|
/*************************************************************************
|
2001-02-17 14:19:19 +02:00
|
|
|
Checks if a read view sees the specified transaction. */
|
|
|
|
UNIV_INLINE
|
|
|
|
ibool
|
|
|
|
read_view_sees_trx_id(
|
|
|
|
/*==================*/
|
|
|
|
/* out: TRUE if sees */
|
|
|
|
read_view_t* view, /* in: read view */
|
|
|
|
dulint trx_id); /* in: trx id */
|
2001-10-30 17:38:44 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Prints a read view to stderr. */
|
|
|
|
|
|
|
|
void
|
|
|
|
read_view_print(
|
|
|
|
/*============*/
|
|
|
|
read_view_t* view); /* in: read view */
|
2005-07-22 14:10:03 +03:00
|
|
|
/*************************************************************************
|
|
|
|
Create a consistent cursor view for mysql to be used in cursors. In this
|
|
|
|
consistent read view modifications done by the creating transaction or future
|
|
|
|
transactions are not visible. */
|
|
|
|
|
|
|
|
cursor_view_t*
|
|
|
|
read_cursor_view_create_for_mysql(
|
|
|
|
/*==============================*/
|
|
|
|
trx_t* cr_trx);/* in: trx where cursor view is created */
|
|
|
|
/*************************************************************************
|
2005-08-03 17:09:21 +03:00
|
|
|
Close a given consistent cursor view for mysql and restore global read view
|
|
|
|
back to a transaction read view. */
|
2005-07-22 14:10:03 +03:00
|
|
|
|
|
|
|
void
|
|
|
|
read_cursor_view_close_for_mysql(
|
|
|
|
/*=============================*/
|
|
|
|
trx_t* trx, /* in: trx */
|
|
|
|
cursor_view_t* curview); /* in: cursor view to be closed */
|
|
|
|
/*************************************************************************
|
|
|
|
This function sets a given consistent cursor view to a transaction
|
2005-08-03 17:09:21 +03:00
|
|
|
read view if given consistent cursor view is not NULL. Otherwise, function
|
2005-07-22 14:10:03 +03:00
|
|
|
restores a global read view to a transaction read view. */
|
|
|
|
|
|
|
|
void
|
|
|
|
read_cursor_set_for_mysql(
|
|
|
|
/*======================*/
|
|
|
|
trx_t* trx, /* in: transaction where cursor is set */
|
|
|
|
cursor_view_t* curview);/* in: consistent cursor view to be set */
|
2001-02-17 14:19:19 +02:00
|
|
|
|
|
|
|
/* Read view lists the trx ids of those transactions for which a consistent
|
|
|
|
read should not see the modifications to the database. */
|
|
|
|
|
|
|
|
struct read_view_struct{
|
|
|
|
ibool can_be_too_old; /* TRUE if the system has had to purge old
|
|
|
|
versions which this read view should be able
|
|
|
|
to access: the read view can bump into the
|
|
|
|
DB_MISSING_HISTORY error */
|
|
|
|
dulint low_limit_no; /* The view does not need to see the undo
|
|
|
|
logs for transactions whose transaction number
|
|
|
|
is strictly smaller (<) than this value: they
|
|
|
|
can be removed in purge if not needed by other
|
|
|
|
views */
|
|
|
|
dulint low_limit_id; /* The read should not see any transaction
|
|
|
|
with trx id >= this value */
|
|
|
|
dulint up_limit_id; /* The read should see all trx ids which
|
|
|
|
are strictly smaller (<) than this value */
|
|
|
|
ulint n_trx_ids; /* Number of cells in the trx_ids array */
|
|
|
|
dulint* trx_ids; /* Additional trx ids which the read should
|
|
|
|
not see: typically, these are the active
|
|
|
|
transactions at the time when the read is
|
|
|
|
serialized, except the reading transaction
|
|
|
|
itself; the trx ids in this array are in a
|
|
|
|
descending order */
|
|
|
|
trx_t* creator; /* Pointer to the creating transaction, or
|
|
|
|
NULL if used in purge */
|
|
|
|
UT_LIST_NODE_T(read_view_t) view_list;
|
|
|
|
/* List of read views in trx_sys */
|
|
|
|
};
|
|
|
|
|
2005-07-22 14:10:03 +03:00
|
|
|
/* Implement InnoDB framework to support consistent read views in
|
|
|
|
cursors. This struct holds both heap where consistent read view
|
|
|
|
is allocated and pointer to a read view. */
|
|
|
|
|
|
|
|
struct cursor_view_struct{
|
|
|
|
mem_heap_t* heap;
|
|
|
|
/* Memory heap for the cursor view */
|
|
|
|
read_view_t* read_view;
|
|
|
|
/* Consistent read view of the cursor*/
|
2005-08-10 18:36:13 +04:00
|
|
|
ulint n_mysql_tables_in_use;
|
|
|
|
/* number of Innobase tables used in the
|
|
|
|
processing of this cursor */
|
2005-07-22 14:10:03 +03:00
|
|
|
};
|
|
|
|
|
2001-02-17 14:19:19 +02:00
|
|
|
#ifndef UNIV_NONINL
|
|
|
|
#include "read0read.ic"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|