2007-04-04 13:05:33 +02:00
|
|
|
/******************************************************
|
|
|
|
Index build routines using a merge sort
|
|
|
|
|
|
|
|
(c) 2005 Innobase Oy
|
|
|
|
|
|
|
|
Created 13/06/2005 Jan Lindstrom
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#ifndef row0merge_h
|
|
|
|
#define row0merge_h
|
|
|
|
|
|
|
|
#include "univ.i"
|
|
|
|
#include "data0data.h"
|
|
|
|
#include "dict0types.h"
|
|
|
|
#include "trx0types.h"
|
|
|
|
#include "que0types.h"
|
|
|
|
#include "mtr0mtr.h"
|
|
|
|
#include "rem0types.h"
|
|
|
|
#include "rem0rec.h"
|
|
|
|
#include "read0types.h"
|
|
|
|
#include "btr0types.h"
|
|
|
|
#include "row0mysql.h"
|
|
|
|
|
|
|
|
/* This structure holds index field definitions */
|
|
|
|
|
|
|
|
struct merge_index_field_struct {
|
2007-08-10 17:22:47 +02:00
|
|
|
ulint prefix_len; /* Prefix len */
|
|
|
|
const char* field_name; /* Field name */
|
2007-04-04 13:05:33 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct merge_index_field_struct merge_index_field_t;
|
|
|
|
|
|
|
|
/* This structure holds index definitions */
|
|
|
|
|
|
|
|
struct merge_index_def_struct {
|
2007-08-10 17:22:47 +02:00
|
|
|
const char* name; /* Index name */
|
|
|
|
ulint ind_type; /* 0, DICT_UNIQUE,
|
|
|
|
or DICT_CLUSTERED */
|
|
|
|
ulint n_fields; /* Number of fields in index */
|
|
|
|
merge_index_field_t* fields; /* Field definitions */
|
2007-04-04 13:05:33 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct merge_index_def_struct merge_index_def_t;
|
|
|
|
|
2007-08-21 14:10:14 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Sets an exclusive lock on a table, for the duration of creating indexes. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
row_merge_lock_table(
|
|
|
|
/*=================*/
|
|
|
|
/* out: error code or DB_SUCCESS */
|
|
|
|
trx_t* trx, /* in/out: transaction */
|
|
|
|
dict_table_t* table); /* in: table to LOCK_X */
|
2007-06-04 09:49:31 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Drop an index from the InnoDB system tables. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
2007-06-04 09:49:31 +02:00
|
|
|
void
|
|
|
|
row_merge_drop_index(
|
|
|
|
/*=================*/
|
|
|
|
dict_index_t* index, /* in: index to be removed */
|
|
|
|
dict_table_t* table, /* in: table */
|
|
|
|
trx_t* trx); /* in: transaction handle */
|
|
|
|
/*************************************************************************
|
|
|
|
Drop those indexes which were created before an error occurred
|
|
|
|
when building an index. */
|
|
|
|
|
|
|
|
void
|
|
|
|
row_merge_drop_indexes(
|
|
|
|
/*===================*/
|
|
|
|
trx_t* trx, /* in: transaction */
|
|
|
|
dict_table_t* table, /* in: table containing the indexes */
|
|
|
|
dict_index_t** index, /* in: indexes to drop */
|
|
|
|
ulint num_created); /* in: number of elements in index[] */
|
2007-09-05 12:18:03 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Drop all partially created indexes during crash recovery. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
2007-09-05 12:18:03 +02:00
|
|
|
void
|
|
|
|
row_merge_drop_temp_indexes(void);
|
|
|
|
/*=============================*/
|
2007-08-20 13:40:00 +02:00
|
|
|
/*************************************************************************
|
|
|
|
Rename the tables in the data dictionary. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
row_merge_rename_tables(
|
|
|
|
/*====================*/
|
|
|
|
/* out: error code or DB_SUCCESS */
|
|
|
|
dict_table_t* old_table, /* in/out: old table, renamed to
|
|
|
|
tmp_name */
|
|
|
|
dict_table_t* new_table, /* in/out: new table, renamed to
|
|
|
|
old_table->name */
|
|
|
|
const char* tmp_name, /* in: new name for old_table */
|
|
|
|
trx_t* trx); /* in: transaction handle */
|
|
|
|
|
2007-04-04 13:05:33 +02:00
|
|
|
/*************************************************************************
|
2007-08-10 17:52:09 +02:00
|
|
|
Create a temporary table for creating a primary key, using the definition
|
|
|
|
of an existing table. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
|
|
|
dict_table_t*
|
|
|
|
row_merge_create_temporary_table(
|
|
|
|
/*=============================*/
|
2007-08-10 17:52:09 +02:00
|
|
|
/* out: table,
|
|
|
|
or NULL on error */
|
|
|
|
const char* table_name, /* in: new table name */
|
|
|
|
const merge_index_def_t*index_def, /* in: the index definition
|
|
|
|
of the primary key */
|
|
|
|
const dict_table_t* table, /* in: old table definition */
|
|
|
|
trx_t* trx); /* in/out: transaction
|
|
|
|
(sets error_state) */
|
2007-04-04 13:05:33 +02:00
|
|
|
/*************************************************************************
|
2007-09-05 12:18:03 +02:00
|
|
|
Rename the temporary indexes in the dictionary to permanent ones. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
|
|
|
ulint
|
2007-09-05 12:18:03 +02:00
|
|
|
row_merge_rename_indexes(
|
|
|
|
/*=====================*/
|
2007-04-04 13:05:33 +02:00
|
|
|
/* out: DB_SUCCESS if all OK */
|
2007-09-05 12:18:03 +02:00
|
|
|
trx_t* trx, /* in/out: transaction */
|
|
|
|
dict_table_t* table); /* in/out: table with new indexes */
|
2007-04-04 13:05:33 +02:00
|
|
|
/*************************************************************************
|
2007-06-08 09:37:07 +02:00
|
|
|
Create the index and load in to the dictionary. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
2007-06-06 22:25:35 +02:00
|
|
|
dict_index_t*
|
2007-04-04 13:05:33 +02:00
|
|
|
row_merge_create_index(
|
|
|
|
/*===================*/
|
2007-06-06 22:25:35 +02:00
|
|
|
/* out: index, or NULL on error */
|
|
|
|
trx_t* trx, /* in/out: trx (sets error_state) */
|
2007-04-04 13:05:33 +02:00
|
|
|
dict_table_t* table, /* in: the index is on this table */
|
|
|
|
const merge_index_def_t* /* in: the index definition */
|
|
|
|
index_def);
|
2007-09-03 09:13:59 +02:00
|
|
|
#ifdef ROW_MERGE_IS_INDEX_USABLE
|
2007-04-04 13:05:33 +02:00
|
|
|
/*************************************************************************
|
2007-06-08 09:37:07 +02:00
|
|
|
Check if a transaction can use an index. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
|
|
|
ibool
|
|
|
|
row_merge_is_index_usable(
|
|
|
|
/*======================*/
|
|
|
|
/* out: TRUE if index can be used by
|
|
|
|
the transaction else FALSE*/
|
2007-04-11 10:16:14 +02:00
|
|
|
const trx_t* trx, /* in: transaction */
|
|
|
|
const dict_index_t* index); /* in: index to check */
|
2007-09-03 09:13:59 +02:00
|
|
|
#endif /* ROW_MERGE_IS_INDEX_USABLE */
|
2007-04-04 13:05:33 +02:00
|
|
|
/*************************************************************************
|
|
|
|
If there are views that refer to the old table name then we "attach" to
|
2007-06-08 09:37:07 +02:00
|
|
|
the new instance of the table else we drop it immediately. */
|
2007-04-04 13:05:33 +02:00
|
|
|
|
|
|
|
ulint
|
|
|
|
row_merge_drop_table(
|
|
|
|
/*=================*/
|
2007-06-08 09:37:07 +02:00
|
|
|
/* out: DB_SUCCESS or error code */
|
2007-04-04 13:05:33 +02:00
|
|
|
trx_t* trx, /* in: transaction */
|
|
|
|
dict_table_t* table); /* in: table instance to drop */
|
2007-06-08 09:37:07 +02:00
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
Build indexes on a table by reading a clustered index,
|
|
|
|
creating a temporary file containing index entries, merge sorting
|
|
|
|
these index entries and inserting sorted index entries to indexes. */
|
|
|
|
|
|
|
|
ulint
|
|
|
|
row_merge_build_indexes(
|
|
|
|
/*====================*/
|
|
|
|
/* out: DB_SUCCESS or error code */
|
|
|
|
trx_t* trx, /* in: transaction */
|
2007-08-10 17:22:47 +02:00
|
|
|
dict_table_t* old_table, /* in: table where rows are
|
2007-06-08 09:37:07 +02:00
|
|
|
read from */
|
2007-08-10 17:22:47 +02:00
|
|
|
dict_table_t* new_table, /* in: table where indexes are
|
|
|
|
created; identical to old_table
|
|
|
|
unless creating a PRIMARY KEY */
|
2007-06-08 09:37:07 +02:00
|
|
|
dict_index_t** indexes, /* in: indexes to be created */
|
branches/zip: Implement the reporting of duplicate key values to MySQL.
innobase_rec_to_mysql(): New function, for converting an InnoDB clustered
index record to MySQL table->record[0]. TODO: convert integer fields.
Currently, integer fields are in big-endian byte order instead of
host byte order, and signed integer fields are offset by 0x80000000.
innobase_rec_reset(): New function, for resetting table->record[0].
row_merge_build_indexes(): Add the parameter TABLE* table (the MySQL table
handle) for reporting duplicate key values.
dtuple_from_fields(): New function, to convert an array of dfield_t* to
dtuple_t.
dtuple_get_n_ext(): New function, to compute the number of externally stored
fields.
row_merge_dup_t: Structure for counting and reporting duplicate records.
row_merge_dup_report(): Function for counting and reporting duplicate records.
row_merge_tuple_cmp(), row_merge_tuple_sort(): Replace the ulint* n_dup
parameter with row_merge_dup_t* dup.
row_merge_buf_sort(): Add the parameter row_merge_dup_t* dup, which is
NULL when sorting a non-unique index.
row_merge_buf_write(), row_merge_heap_create(), row_merge_read_rec(),
row_merge_cmp(), row_merge_read_clustered_index(), row_merge_blocks(),
row_merge(), row_merge_sort(): Add const qualifiers.
row_merge_read_clustered_index(): Use a common error handling branch err_exit.
Invoke row_merge_buf_sort() differently on unique indexes.
row_merge_blocks(): note TODO: We could invoke innobase_rec_to_mysql()
to report duplicate key values when creating a clustered index.
2007-09-26 13:56:26 +02:00
|
|
|
ulint n_indexes, /* in: size of indexes[] */
|
|
|
|
TABLE* table); /* in/out: MySQL table, for
|
|
|
|
reporting erroneous key value
|
|
|
|
if applicable */
|
2007-04-04 13:05:33 +02:00
|
|
|
#endif /* row0merge.h */
|