2009-02-17 08:59:22 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
|
|
|
|
Copyright (c) 1994, 2009, Innobase Oy. All Rights Reserved.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; version 2 of the License.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|
|
|
Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
2005-10-27 07:29:40 +00:00
|
|
|
/************************************************************************
|
|
|
|
SQL data field and tuple
|
|
|
|
|
|
|
|
Created 5/30/1994 Heikki Tuuri
|
|
|
|
*************************************************************************/
|
|
|
|
|
|
|
|
#ifndef data0data_h
|
|
|
|
#define data0data_h
|
|
|
|
|
|
|
|
#include "univ.i"
|
|
|
|
|
|
|
|
#include "data0types.h"
|
|
|
|
#include "data0type.h"
|
|
|
|
#include "mem0mem.h"
|
|
|
|
#include "dict0types.h"
|
|
|
|
|
|
|
|
typedef struct big_rec_struct big_rec_t;
|
|
|
|
|
2006-10-19 07:27:26 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets pointer to the type struct of SQL data field.
|
|
|
|
@return pointer to the type struct */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
2006-10-19 07:27:26 +00:00
|
|
|
dtype_t*
|
2005-10-27 07:29:40 +00:00
|
|
|
dfield_get_type(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: SQL data field */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets pointer to the data in a field.
|
|
|
|
@return pointer to data */
|
2006-10-19 07:27:26 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
void*
|
|
|
|
dfield_get_data(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: field */
|
2006-10-19 07:27:26 +00:00
|
|
|
#else /* UNIV_DEBUG */
|
|
|
|
# define dfield_get_type(field) (&(field)->type)
|
|
|
|
# define dfield_get_data(field) ((field)->data)
|
|
|
|
#endif /* UNIV_DEBUG */
|
|
|
|
/*************************************************************************
|
2005-10-27 07:29:40 +00:00
|
|
|
Sets the type struct of SQL data field. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dfield_set_type(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field, /*!< in: SQL data field */
|
|
|
|
dtype_t* type); /*!< in: pointer to data type struct */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets length of field data.
|
|
|
|
@return length of data; UNIV_SQL_NULL if SQL null data */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dfield_get_len(
|
|
|
|
/*===========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: field */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Sets length in a field. */
|
|
|
|
UNIV_INLINE
|
2006-02-23 19:25:29 +00:00
|
|
|
void
|
2005-10-27 07:29:40 +00:00
|
|
|
dfield_set_len(
|
|
|
|
/*===========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field, /*!< in: field */
|
|
|
|
ulint len); /*!< in: length or UNIV_SQL_NULL */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Determines if a field is SQL NULL
|
|
|
|
@return nonzero if SQL null data */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dfield_is_null(
|
|
|
|
/*===========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: field */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Determines if a field is externally stored
|
|
|
|
@return nonzero if externally stored */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dfield_is_ext(
|
|
|
|
/*==========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: field */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Sets the "external storage" flag */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dfield_set_ext(
|
|
|
|
/*===========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field); /*!< in/out: field */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
/*************************************************************************
|
2005-10-27 07:29:40 +00:00
|
|
|
Sets pointer to the data and length in a field. */
|
|
|
|
UNIV_INLINE
|
2006-02-23 19:25:29 +00:00
|
|
|
void
|
2005-10-27 07:29:40 +00:00
|
|
|
dfield_set_data(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field, /*!< in: field */
|
|
|
|
const void* data, /*!< in: data */
|
|
|
|
ulint len); /*!< in: length or UNIV_SQL_NULL */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Sets a data field to SQL NULL. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dfield_set_null(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field); /*!< in/out: field */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************************
|
|
|
|
Writes an SQL null field full of zeros. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
data_write_sql_null(
|
|
|
|
/*================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
byte* data, /*!< in: pointer to a buffer of size len */
|
|
|
|
ulint len); /*!< in: SQL null size in bytes */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Copies the data and len fields. */
|
|
|
|
UNIV_INLINE
|
2006-02-23 19:25:29 +00:00
|
|
|
void
|
2005-10-27 07:29:40 +00:00
|
|
|
dfield_copy_data(
|
|
|
|
/*=============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field1, /*!< out: field to copy to */
|
|
|
|
const dfield_t* field2);/*!< in: field to copy from */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Copies a data field to another. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dfield_copy(
|
|
|
|
/*========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field1, /*!< out: field to copy to */
|
|
|
|
const dfield_t* field2);/*!< in: field to copy from */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2007-10-23 06:46:12 +00:00
|
|
|
Copies the data pointed to by a data field. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dfield_dup(
|
|
|
|
/*=======*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dfield_t* field, /*!< in/out: data field */
|
|
|
|
mem_heap_t* heap); /*!< in: memory heap where allocated */
|
2007-10-23 06:46:12 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Tests if data length and content is equal for two dfields.
|
|
|
|
@return TRUE if equal */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ibool
|
|
|
|
dfield_datas_are_binary_equal(
|
|
|
|
/*==========================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field1, /*!< in: field */
|
|
|
|
const dfield_t* field2);/*!< in: field */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Tests if dfield data length and content is equal to the given.
|
|
|
|
@return TRUE if equal */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool
|
|
|
|
dfield_data_is_binary_equal(
|
|
|
|
/*========================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field, /*!< in: field */
|
|
|
|
ulint len, /*!< in: data length or UNIV_SQL_NULL */
|
|
|
|
const byte* data); /*!< in: data */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets number of fields in a data tuple.
|
|
|
|
@return number of fields */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
2006-02-23 19:25:29 +00:00
|
|
|
ulint
|
2005-10-27 07:29:40 +00:00
|
|
|
dtuple_get_n_fields(
|
|
|
|
/*================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2006-10-19 07:27:26 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets nth field of a tuple.
|
|
|
|
@return nth field */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
2006-10-19 07:27:26 +00:00
|
|
|
dfield_t*
|
2005-10-27 07:29:40 +00:00
|
|
|
dtuple_get_nth_field(
|
|
|
|
/*=================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple, /*!< in: tuple */
|
|
|
|
ulint n); /*!< in: index of field */
|
2006-10-19 07:27:26 +00:00
|
|
|
#else /* UNIV_DEBUG */
|
|
|
|
# define dtuple_get_nth_field(tuple, n) ((tuple)->fields + (n))
|
|
|
|
#endif /* UNIV_DEBUG */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets info bits in a data tuple.
|
|
|
|
@return info bits */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dtuple_get_info_bits(
|
|
|
|
/*=================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Sets info bits in a data tuple. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dtuple_set_info_bits(
|
|
|
|
/*=================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dtuple_t* tuple, /*!< in: tuple */
|
|
|
|
ulint info_bits); /*!< in: info bits */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets number of fields used in record comparisons.
|
|
|
|
@return number of fields used in comparisons in rem0cmp.* */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dtuple_get_n_fields_cmp(
|
|
|
|
/*====================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Gets number of fields used in record comparisons. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dtuple_set_n_fields_cmp(
|
|
|
|
/*====================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dtuple_t* tuple, /*!< in: tuple */
|
|
|
|
ulint n_fields_cmp); /*!< in: number of fields used in
|
2005-10-27 07:29:40 +00:00
|
|
|
comparisons in rem0cmp.* */
|
|
|
|
/**************************************************************
|
|
|
|
Creates a data tuple to a memory heap. The default value for number
|
2009-05-25 05:30:14 +00:00
|
|
|
of fields used in record comparisons for this tuple is n_fields.
|
|
|
|
@return own: created tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
dtuple_t*
|
|
|
|
dtuple_create(
|
|
|
|
/*==========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mem_heap_t* heap, /*!< in: memory heap where the tuple
|
2005-10-27 07:29:40 +00:00
|
|
|
is created */
|
2009-05-25 05:30:14 +00:00
|
|
|
ulint n_fields); /*!< in: number of fields */
|
2005-10-27 07:29:40 +00:00
|
|
|
|
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 11:56:26 +00:00
|
|
|
/**************************************************************
|
|
|
|
Wrap data fields in a tuple. The default value for number
|
2009-05-25 05:30:14 +00:00
|
|
|
of fields used in record comparisons for this tuple is n_fields.
|
|
|
|
@return data tuple */
|
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 11:56:26 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
const dtuple_t*
|
|
|
|
dtuple_from_fields(
|
|
|
|
/*===============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dtuple_t* tuple, /*!< in: storage for data tuple */
|
|
|
|
const dfield_t* fields, /*!< in: fields */
|
|
|
|
ulint n_fields); /*!< in: number of fields */
|
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 11:56:26 +00:00
|
|
|
|
2005-10-27 07:29:40 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Sets number of fields used in a tuple. Normally this is set in
|
2006-02-23 19:25:29 +00:00
|
|
|
dtuple_create, but if you want later to set it smaller, you can use this. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dtuple_set_n_fields(
|
|
|
|
/*================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dtuple_t* tuple, /*!< in: tuple */
|
|
|
|
ulint n_fields); /*!< in: number of fields */
|
2008-01-16 10:10:32 +00:00
|
|
|
/*************************************************************************
|
|
|
|
Copies a data tuple to another. This is a shallow copy; if a deep copy
|
2009-05-25 05:30:14 +00:00
|
|
|
is desired, dfield_dup() will have to be invoked on each field.
|
|
|
|
@return own: copy of tuple */
|
2008-01-16 10:10:32 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
dtuple_t*
|
|
|
|
dtuple_copy(
|
|
|
|
/*========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple, /*!< in: tuple to copy from */
|
|
|
|
mem_heap_t* heap); /*!< in: memory heap
|
2008-01-16 10:10:32 +00:00
|
|
|
where the tuple is created */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************
|
|
|
|
The following function returns the sum of data lengths of a tuple. The space
|
2009-05-25 05:30:14 +00:00
|
|
|
occupied by the field structs or the tuple struct is not counted.
|
|
|
|
@return sum of data lens */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dtuple_get_data_size(
|
|
|
|
/*=================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple, /*!< in: typed data tuple */
|
|
|
|
ulint comp); /*!< in: nonzero=ROW_FORMAT=COMPACT */
|
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 11:56:26 +00:00
|
|
|
/*************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Computes the number of externally stored fields in a data tuple.
|
|
|
|
@return number of fields */
|
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 11:56:26 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dtuple_get_n_ext(
|
|
|
|
/*=============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/****************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Compare two data tuples, respecting the collation of character fields.
|
|
|
|
@return 1, 0 , -1 if tuple1 is greater, equal, less, respectively, than tuple2 */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2007-05-22 09:34:25 +00:00
|
|
|
int
|
|
|
|
dtuple_coll_cmp(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple1, /*!< in: tuple 1 */
|
|
|
|
const dtuple_t* tuple2);/*!< in: tuple 2 */
|
2005-10-27 07:29:40 +00:00
|
|
|
/****************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Folds a prefix given as the number of fields of a tuple.
|
|
|
|
@return the folded value */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
dtuple_fold(
|
|
|
|
/*========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple, /*!< in: the tuple */
|
|
|
|
ulint n_fields,/*!< in: number of complete fields to fold */
|
|
|
|
ulint n_bytes,/*!< in: number of bytes to fold in an
|
2005-10-27 07:29:40 +00:00
|
|
|
incomplete last field */
|
2009-05-25 05:30:14 +00:00
|
|
|
dulint tree_id)/*!< in: index tree id */
|
2007-01-03 12:34:54 +00:00
|
|
|
__attribute__((pure));
|
2005-10-27 07:29:40 +00:00
|
|
|
/***********************************************************************
|
|
|
|
Sets types of fields binary in a tuple. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
dtuple_set_types_binary(
|
|
|
|
/*====================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dtuple_t* tuple, /*!< in: data tuple */
|
|
|
|
ulint n); /*!< in: number of fields to set */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks if a dtuple contains an SQL null value.
|
|
|
|
@return TRUE if some field is SQL null */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ibool
|
|
|
|
dtuple_contains_null(
|
|
|
|
/*=================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: dtuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks that a data field is typed. Asserts an error if not.
|
|
|
|
@return TRUE if ok */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool
|
|
|
|
dfield_check_typed(
|
|
|
|
/*===============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* field); /*!< in: data field */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks that a data tuple is typed. Asserts an error if not.
|
|
|
|
@return TRUE if ok */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool
|
|
|
|
dtuple_check_typed(
|
|
|
|
/*===============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks that a data tuple is typed.
|
|
|
|
@return TRUE if ok */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool
|
|
|
|
dtuple_check_typed_no_assert(
|
|
|
|
/*=========================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
/**************************************************************
|
|
|
|
Validates the consistency of a tuple which must be complete, i.e,
|
2009-05-25 05:30:14 +00:00
|
|
|
all fields must have been set.
|
|
|
|
@return TRUE if ok */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool
|
|
|
|
dtuple_validate(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
#endif /* UNIV_DEBUG */
|
|
|
|
/*****************************************************************
|
|
|
|
Pretty prints a dfield value according to its data type. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dfield_print(
|
|
|
|
/*=========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* dfield);/*!< in: dfield */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*****************************************************************
|
|
|
|
Pretty prints a dfield value according to its data type. Also the hex string
|
2006-02-23 19:25:29 +00:00
|
|
|
is printed if a string contains non-printable characters. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dfield_print_also_hex(
|
|
|
|
/*==================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const dfield_t* dfield); /*!< in: dfield */
|
2005-10-27 07:29:40 +00:00
|
|
|
/**************************************************************
|
|
|
|
The following function prints the contents of a tuple. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dtuple_print(
|
|
|
|
/*=========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
FILE* f, /*!< in: output stream */
|
|
|
|
const dtuple_t* tuple); /*!< in: tuple */
|
2005-10-27 07:29:40 +00:00
|
|
|
/******************************************************************
|
|
|
|
Moves parts of long fields in entry to the big record vector so that
|
|
|
|
the size of tuple drops below the maximum record size allowed in the
|
|
|
|
database. Moves data only from those fields which are not necessary
|
2009-05-25 05:30:14 +00:00
|
|
|
to determine uniquely the insertion place of the tuple in the index.
|
|
|
|
@return own: created big record vector, NULL if we are not able to shorten the entry enough, i.e., if there are too many fixed-length or short fields in entry or the index is clustered */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
big_rec_t*
|
|
|
|
dtuple_convert_big_rec(
|
|
|
|
/*===================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dict_index_t* index, /*!< in: index */
|
|
|
|
dtuple_t* entry, /*!< in/out: index entry */
|
|
|
|
ulint* n_ext); /*!< in/out: number of
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
externally stored columns */
|
2005-10-27 07:29:40 +00:00
|
|
|
/******************************************************************
|
|
|
|
Puts back to entry the data stored in vector. Note that to ensure the
|
|
|
|
fields in entry can accommodate the data, vector must have been created
|
|
|
|
from entry with dtuple_convert_big_rec. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dtuple_convert_back_big_rec(
|
|
|
|
/*========================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
dict_index_t* index, /*!< in: index */
|
|
|
|
dtuple_t* entry, /*!< in: entry whose data was put to vector */
|
|
|
|
big_rec_t* vector);/*!< in, own: big rec vector; it is
|
2005-10-27 07:29:40 +00:00
|
|
|
freed in this function */
|
|
|
|
/******************************************************************
|
|
|
|
Frees the memory in a big rec vector. */
|
2007-03-28 18:31:16 +00:00
|
|
|
UNIV_INLINE
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
dtuple_big_rec_free(
|
|
|
|
/*================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
big_rec_t* vector); /*!< in, own: big rec vector; it is
|
2005-10-27 07:29:40 +00:00
|
|
|
freed in this function */
|
|
|
|
|
|
|
|
/*######################################################################*/
|
|
|
|
|
|
|
|
/* Structure for an SQL data field */
|
|
|
|
struct dfield_struct{
|
|
|
|
void* data; /* pointer to data */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
unsigned ext:1; /* TRUE=externally stored, FALSE=local */
|
|
|
|
unsigned len:32; /* data length; UNIV_SQL_NULL if SQL null */
|
2005-10-27 07:29:40 +00:00
|
|
|
dtype_t type; /* type of data */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct dtuple_struct {
|
|
|
|
ulint info_bits; /* info bits of an index record:
|
|
|
|
the default is 0; this field is used
|
|
|
|
if an index record is built from
|
|
|
|
a data tuple */
|
|
|
|
ulint n_fields; /* number of fields in dtuple */
|
|
|
|
ulint n_fields_cmp; /* number of fields which should
|
|
|
|
be used in comparison services
|
|
|
|
of rem0cmp.*; the index search
|
|
|
|
is performed by comparing only these
|
|
|
|
fields, others are ignored; the
|
|
|
|
default value in dtuple creation is
|
|
|
|
the same value as n_fields */
|
|
|
|
dfield_t* fields; /* fields */
|
|
|
|
UT_LIST_NODE_T(dtuple_t) tuple_list;
|
|
|
|
/* data tuples can be linked into a
|
|
|
|
list using this field */
|
2007-09-26 06:37:17 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2006-02-23 19:25:29 +00:00
|
|
|
ulint magic_n;
|
2007-09-26 06:37:17 +00:00
|
|
|
# define DATA_TUPLE_MAGIC_N 65478679
|
|
|
|
#endif /* UNIV_DEBUG */
|
2005-10-27 07:29:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* A slot for a field in a big rec vector */
|
|
|
|
|
2006-02-23 19:25:29 +00:00
|
|
|
typedef struct big_rec_field_struct big_rec_field_t;
|
2005-10-27 07:29:40 +00:00
|
|
|
struct big_rec_field_struct {
|
|
|
|
ulint field_no; /* field number in record */
|
|
|
|
ulint len; /* stored data len */
|
branches/zip: Make merge sort handle externally stored columns.
Some things still fail in innodb-index.test, and there seems to be
a race condition (data dictionary lock wait) when running with --valgrind.
dfield_t: Add an "external storage" flag, dfield->ext.
dfield_is_null(), dfield_is_ext(), dfield_set_ext(), dfield_set_null():
New functions.
dfield_copy(), dfield_copy_data(): Add const qualifiers, fix in/out comments.
data_write_sql_null(): Use memset().
big_rec_field_t: Replace byte* data with const void* data.
ut_ulint_sort(): Remove.
upd_field_t: Remove extern_storage.
upd_node_t: Replace ext_vec, n_ext_vec with n_ext.
row_merge_copy_blobs(): New function.
row_ins_index_entry(): Add the parameter "ibool foreign" for suppressing
foreign key checks during fast index creation or when inserting into
secondary indexes.
btr_page_insert_fits(): Add const qualifiers.
btr_cur_add_ext(), upd_ext_vec_contains(): Remove.
dfield_print_also_hex(), dfield_print(): Replace if...else if with switch.
Observe dfield_is_ext().
2007-06-21 09:43:15 +00:00
|
|
|
const void* data; /* stored data */
|
2005-10-27 07:29:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Storage format for overflow data in a big record, that is, a record
|
|
|
|
which needs external storage of data fields */
|
|
|
|
|
|
|
|
struct big_rec_struct {
|
|
|
|
mem_heap_t* heap; /* memory heap from which allocated */
|
|
|
|
ulint n_fields; /* number of stored fields */
|
|
|
|
big_rec_field_t* fields; /* stored fields */
|
|
|
|
};
|
2006-02-23 19:25:29 +00:00
|
|
|
|
2005-10-27 07:29:40 +00:00
|
|
|
#ifndef UNIV_NONINL
|
|
|
|
#include "data0data.ic"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|