polardbxengine/storage/innobase/include/handler0alter.h

111 lines
4.1 KiB
C

/*****************************************************************************
Copyright (c) 2005, 2019, Oracle and/or its affiliates. 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, version 2.0, as published by the
Free Software Foundation.
This program is also distributed with certain software (including but not
limited to OpenSSL) that is licensed under separate terms, as designated in a
particular file or component or in included license documentation. The authors
of MySQL hereby grant you an additional permission to link the program and
your derivative works with the separately licensed software that they have
included with MySQL.
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, version 2.0,
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.,
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*****************************************************************************/
/** @file include/handler0alter.h
Smart ALTER TABLE
*******************************************************/
#ifndef handler0alter_h
#define handler0alter_h
/** Copies an InnoDB record to table->record[0]. */
void innobase_rec_to_mysql(struct TABLE *table, /*!< in/out: MySQL table */
const rec_t *rec, /*!< in: record */
const dict_index_t *index, /*!< in: index */
const ulint *offsets); /*!< in: rec_get_offsets(
rec, index, ...) */
/** Copies an InnoDB index entry to table->record[0]. */
void innobase_fields_to_mysql(
struct TABLE *table, /*!< in/out: MySQL table */
const dict_index_t *index, /*!< in: InnoDB index */
const dfield_t *fields); /*!< in: InnoDB index fields */
/** Copies an InnoDB row to table->record[0]. */
void innobase_row_to_mysql(struct TABLE *table, /*!< in/out: MySQL table */
const dict_table_t *itab, /*!< in: InnoDB table */
const dtuple_t *row); /*!< in: InnoDB row */
/** Resets table->record[0]. */
void innobase_rec_reset(struct TABLE *table); /*!< in/out: MySQL table */
/** Generate the next autoinc based on a snapshot of the session
auto_increment_increment and auto_increment_offset variables.
Assingnment operator would be used during the inplace_alter_table()
phase only **/
struct ib_sequence_t {
/**
@param thd the session
@param start_value the lower bound
@param max_value the upper bound (inclusive) */
ib_sequence_t(THD *thd, ulonglong start_value, ulonglong max_value);
/** Postfix increment
@return the value to insert */
ulonglong operator++(int) UNIV_NOTHROW;
/** Check if the autoinc "sequence" is exhausted.
@return true if the sequence is exhausted */
bool eof() const UNIV_NOTHROW { return (m_eof); }
/** assignment operator to copy the sequence values
@param in sequence to copy from */
ib_sequence_t &operator=(const ib_sequence_t &in) {
ut_ad(in.m_next_value > 0);
ut_ad(in.m_max_value == m_max_value);
m_next_value = in.m_next_value;
m_increment = in.m_increment;
m_offset = in.m_offset;
m_eof = in.m_eof;
return (*this);
}
/**
@return the next value in the sequence */
ulonglong last() const UNIV_NOTHROW {
ut_ad(m_next_value > 0);
return (m_next_value);
}
/** Maximum calumn value if adding an AUTOINC column else 0. Once
we reach the end of the sequence it will be set to ~0. */
const ulonglong m_max_value;
/** Value of auto_increment_increment */
ulong m_increment;
/** Value of auto_increment_offset */
ulong m_offset;
/** Next value in the sequence */
ulonglong m_next_value;
/** true if no more values left in the sequence */
bool m_eof;
};
#endif /* handler0alter_h */