mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
f3e4ce926d
into mysql.com:/home/kent/bk/main/mysql-5.1 BUILD/Makefile.am: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~10: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~11: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~12: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~13: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~14: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~15: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~1: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~2f6eabb2f69cb33d: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~2: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~3: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~4ef559bc8b4695f7: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~4: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~5: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~6: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~7: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~84669765249a4bad: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~8: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~9: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~c20dcd005f596740: Auto merged BitKeeper/deleted/.del-CMakeLists.txt~dd682cce1d53c0b4: Auto merged BitKeeper/deleted/.del-Makefile.am~2: Auto merged BitKeeper/deleted/.del-Makefile.am~ab5c84d46412dc2e: Auto merged BitKeeper/deleted/.del-Makefile.am~de166d6fcac3b9b6: Auto merged BitKeeper/deleted/.del-Makefile.am~e5b911533dad2713: Auto merged BitKeeper/deleted/.del-Makefile.am~ead19441cc5ff35c: Auto merged BitKeeper/deleted/.del-Makefile.am~f87185e232d7c4f: Auto merged BitKeeper/deleted/.del-Makefile.in: Auto merged BitKeeper/deleted/.del-ReadMe.txt~573b1e4ebab241e1: Auto merged BitKeeper/deleted/.del-build-vs71.bat: Auto merged BitKeeper/deleted/.del-build-vs8.bat: Auto merged BitKeeper/deleted/.del-configure.js: Auto merged BitKeeper/deleted/.del-copy_mysql_files.bat~f6878eeb80173de9: Auto merged BitKeeper/deleted/.del-ha_berkeley.cc: Auto merged BitKeeper/deleted/.del-ha_berkeley.h: Auto merged BitKeeper/deleted/.del-make_win_bin_dist: Auto merged BitKeeper/deleted/.del-make_win_src_distribution.sh~f80d8fca44e4e5f1: Auto merged BitKeeper/deleted/.del-my_create_tables.c~c121a0c4c427ebb: Auto merged BitKeeper/deleted/.del-mysql_explain_log.sh~5ddc62808e16bd57: Auto merged BitKeeper/deleted/.del-mysql_thr.c~20772782813d1274: Auto merged BitKeeper/deleted/.del-mysql_upgrade.sh~826da969ccf96ef: Auto merged BitKeeper/deleted/.del-mysqlmanager.c~e97636d71145a0b: Auto merged BitKeeper/deleted/.del-prepare~773a10a535120a7e: Auto merged BitKeeper/deleted/.del-print-limit-table~b8e808031daa3758: Auto merged BitKeeper/deleted/.del-sql_manager.h: Auto merged BitKeeper/deleted/.del-thr_test.c~70fc0971c72f2a95: Auto merged Docs/Makefile.am: Auto merged Docs/generate-text-files.pl: Auto merged client/Makefile.am: Auto merged client/client_priv.h: Auto merged client/mysqladmin.cc: Auto merged client/mysqlimport.c: Auto merged client/mysqlshow.c: Auto merged dbug/Makefile.am: Auto merged extra/Makefile.am: Auto merged extra/yassl/taocrypt/benchmark/Makefile.am: Auto merged extra/yassl/taocrypt/test/Makefile.am: Auto merged include/Makefile.am: Auto merged include/my_time.h: Auto merged libmysql/Makefile.am: Auto merged libmysql_r/Makefile.am: Auto merged libmysqld/Makefile.am: Auto merged libmysqld/embedded_priv.h: Auto merged mysql-test/Makefile.am: Auto merged mysql-test/install_test_db.sh: Auto merged mysql-test/lib/mtr_cases.pl: Auto merged mysql-test/lib/mtr_io.pl: Auto merged mysql-test/lib/mtr_match.pl: Auto merged mysql-test/lib/mtr_misc.pl: Auto merged mysql-test/lib/mtr_process.pl: Auto merged mysql-test/lib/mtr_report.pl: Auto merged mysql-test/lib/mtr_timer.pl: Auto merged mysql-test/ndb/ndbcluster.sh: Auto merged mysys/Makefile.am: Auto merged mysys/my_gethostbyname.c: Auto merged mysys/my_getopt.c: Auto merged mysys/my_handler.c: Auto merged regex/Makefile.am: Auto merged scripts/Makefile.am: Auto merged scripts/fill_func_tables.sh: Auto merged scripts/make_binary_distribution.sh: Auto merged scripts/mysql_convert_table_format.sh: Auto merged scripts/mysql_create_system_tables.sh: Auto merged scripts/mysql_fix_privilege_tables.sh: Auto merged scripts/mysql_install_db.sh: Auto merged server-tools/instance-manager/IMService.cpp: Auto merged server-tools/instance-manager/WindowsService.cpp: Auto merged server-tools/instance-manager/listener.cc: Auto merged server-tools/instance-manager/log.cc: Auto merged server-tools/instance-manager/log.h: Auto merged server-tools/instance-manager/manager.cc: Auto merged server-tools/instance-manager/messages.cc: Auto merged server-tools/instance-manager/mysql_connection.cc: Auto merged server-tools/instance-manager/mysqlmanager.cc: Auto merged server-tools/instance-manager/options.cc: Auto merged server-tools/instance-manager/options.h: Auto merged server-tools/instance-manager/portability.h: Auto merged server-tools/instance-manager/priv.cc: Auto merged server-tools/instance-manager/protocol.cc: Auto merged server-tools/instance-manager/protocol.h: Auto merged server-tools/instance-manager/thread_registry.cc: Auto merged server-tools/instance-manager/thread_registry.h: Auto merged server-tools/instance-manager/user_map.cc: Auto merged server-tools/instance-manager/user_map.h: Auto merged sql/Makefile.am: Auto merged sql/discover.cc: Auto merged sql/field.cc: Auto merged sql/field.h: Auto merged sql/filesort.cc: Auto merged sql/gen_lex_hash.cc: Auto merged sql/handler.cc: Auto merged sql/handler.h: Auto merged sql/hostname.cc: Auto merged sql/init.cc: Auto merged sql/item.cc: Auto merged sql/item.h: Auto merged sql/item_cmpfunc.cc: Auto merged sql/item_create.h: Auto merged sql/item_func.h: Auto merged sql/item_geofunc.cc: Auto merged sql/item_strfunc.cc: Auto merged sql/item_sum.h: Auto merged sql/item_timefunc.h: Auto merged sql/item_uniq.cc: Auto merged sql/key.cc: Auto merged sql/lex_symbol.h: Auto merged sql/lock.cc: Auto merged sql/log_event.h: Auto merged sql/my_decimal.cc: Auto merged sql/my_decimal.h: Auto merged sql/my_lock.c: Auto merged sql/opt_range.cc: Auto merged sql/opt_range.h: Auto merged sql/password.c: Auto merged sql/procedure.h: Auto merged sql/protocol.h: Auto merged sql/records.cc: Auto merged sql/repl_failsafe.cc: Auto merged sql/set_var.h: Auto merged sql/spatial.h: Auto merged sql/sql_acl.h: Auto merged sql/sql_analyse.cc: Auto merged sql/sql_analyse.h: Auto merged sql/sql_base.cc: Auto merged sql/sql_cache.h: Auto merged sql/sql_class.cc: Auto merged sql/sql_class.h: Auto merged sql/sql_crypt.cc: Auto merged sql/sql_cursor.cc: Auto merged sql/sql_do.cc: Auto merged sql/sql_insert.cc: Auto merged sql/sql_lex.cc: Auto merged sql/sql_lex.h: Auto merged sql/sql_load.cc: Auto merged sql/sql_manager.cc: Auto merged sql/sql_map.cc: Auto merged sql/sql_olap.cc: Auto merged sql/sql_parse.cc: Auto merged sql/sql_rename.cc: Auto merged sql/sql_repl.cc: Auto merged sql/sql_repl.h: Auto merged sql-bench/Makefile.am: Auto merged sql-bench/as3ap.sh: Auto merged sql-bench/bench-count-distinct.sh: Auto merged sql-bench/bench-init.pl.sh: Auto merged sql-bench/compare-results.sh: Auto merged sql-bench/copy-db.sh: Auto merged sql-bench/crash-me.sh: Auto merged sql-bench/run-all-tests.sh: Auto merged sql-bench/server-cfg.sh: Auto merged sql-bench/test-ATIS.sh: Auto merged sql-bench/test-alter-table.sh: Auto merged sql-bench/test-big-tables.sh: Auto merged sql-bench/test-connect.sh: Auto merged sql-bench/test-create.sh: Auto merged sql-bench/test-insert.sh: Auto merged sql-bench/test-select.sh: Auto merged sql-bench/test-transactions.sh: Auto merged sql-bench/test-wisconsin.sh: Auto merged sql-common/my_time.c: Auto merged sql/sql_select.cc: Auto merged sql/sql_select.h: Auto merged sql/sql_test.cc: Auto merged sql/sql_update.cc: Auto merged sql/structs.h: Auto merged sql/table.cc: Auto merged sql/table.h: Auto merged sql/time.cc: Auto merged sql/unireg.cc: Auto merged sql/unireg.h: Auto merged storage/federated/ha_federated.cc: Auto merged storage/heap/Makefile.am: Auto merged storage/heap/_check.c: Auto merged storage/heap/_rectest.c: Auto merged storage/heap/ha_heap.cc: Auto merged storage/heap/ha_heap.h: Auto merged storage/heap/heapdef.h: Auto merged storage/heap/hp_block.c: Auto merged storage/heap/hp_clear.c: Auto merged storage/heap/hp_close.c: Auto merged storage/heap/hp_create.c: Auto merged storage/heap/hp_delete.c: Auto merged storage/heap/hp_extra.c: Auto merged storage/heap/hp_hash.c: Auto merged storage/heap/hp_info.c: Auto merged storage/heap/hp_open.c: Auto merged storage/heap/hp_panic.c: Auto merged storage/heap/hp_rename.c: Auto merged storage/heap/hp_rfirst.c: Auto merged storage/heap/hp_rkey.c: Auto merged storage/heap/hp_rlast.c: Auto merged storage/heap/hp_rnext.c: Auto merged storage/heap/hp_rprev.c: Auto merged storage/heap/hp_rrnd.c: Auto merged storage/heap/hp_rsame.c: Auto merged storage/heap/hp_scan.c: Auto merged storage/heap/hp_static.c: Auto merged storage/heap/hp_test1.c: Auto merged storage/heap/hp_test2.c: Auto merged storage/heap/hp_update.c: Auto merged storage/heap/hp_write.c: Auto merged storage/innobase/Makefile.am: Auto merged storage/innobase/btr/Makefile.am: Auto merged storage/innobase/buf/Makefile.am: Auto merged storage/innobase/data/Makefile.am: Auto merged storage/innobase/dict/Makefile.am: Auto merged storage/innobase/dyn/Makefile.am: Auto merged storage/innobase/eval/Makefile.am: Auto merged storage/innobase/fil/Makefile.am: Auto merged storage/innobase/fsp/Makefile.am: Auto merged storage/innobase/fut/Makefile.am: Auto merged storage/innobase/ha/Makefile.am: Auto merged storage/innobase/ibuf/Makefile.am: Auto merged storage/innobase/lock/Makefile.am: Auto merged storage/innobase/log/Makefile.am: Auto merged storage/innobase/mach/Makefile.am: Auto merged storage/innobase/mem/Makefile.am: Auto merged storage/innobase/mtr/Makefile.am: Auto merged storage/innobase/os/Makefile.am: Auto merged storage/innobase/page/Makefile.am: Auto merged storage/innobase/pars/Makefile.am: Auto merged storage/innobase/que/Makefile.am: Auto merged storage/innobase/read/Makefile.am: Auto merged storage/innobase/rem/Makefile.am: Auto merged storage/innobase/row/Makefile.am: Auto merged storage/innobase/srv/Makefile.am: Auto merged storage/innobase/sync/Makefile.am: Auto merged storage/innobase/thr/Makefile.am: Auto merged storage/innobase/trx/Makefile.am: Auto merged storage/innobase/usr/Makefile.am: Auto merged storage/innobase/ut/Makefile.am: Auto merged storage/myisam/Makefile.am: Auto merged storage/myisam/ft_boolean_search.c: Auto merged storage/myisam/ft_eval.c: Auto merged storage/myisam/ft_nlq_search.c: Auto merged storage/myisam/ft_parser.c: Auto merged storage/myisam/ft_static.c: Auto merged storage/myisam/ft_stem.c: Auto merged storage/myisam/ft_stopwords.c: Auto merged storage/myisam/ft_test1.c: Auto merged storage/myisam/ft_test1.h: Auto merged storage/myisam/ft_update.c: Auto merged storage/myisam/ftdefs.h: Auto merged storage/myisam/fulltext.h: Auto merged storage/myisam/ha_myisam.cc: Auto merged storage/myisam/ha_myisam.h: Auto merged storage/myisam/mi_cache.c: Auto merged storage/myisam/mi_changed.c: Auto merged storage/myisam/mi_check.c: Auto merged storage/myisam/mi_checksum.c: Auto merged storage/myisam/mi_close.c: Auto merged storage/myisam/mi_create.c: Auto merged storage/myisam/mi_dbug.c: Auto merged storage/myisam/mi_delete.c: Auto merged storage/myisam/mi_delete_all.c: Auto merged storage/myisam/mi_delete_table.c: Auto merged storage/myisam/mi_dynrec.c: Auto merged storage/myisam/mi_extra.c: Auto merged storage/myisam/mi_info.c: Auto merged storage/myisam/mi_key.c: Auto merged storage/myisam/mi_locking.c: Auto merged storage/myisam/mi_log.c: Auto merged storage/myisam/mi_open.c: Auto merged storage/myisam/mi_packrec.c: Auto merged storage/myisam/mi_page.c: Auto merged storage/myisam/mi_panic.c: Auto merged storage/myisam/mi_preload.c: Auto merged storage/myisam/mi_range.c: Auto merged storage/myisam/mi_rename.c: Auto merged storage/myisam/mi_rfirst.c: Auto merged storage/myisam/mi_rkey.c: Auto merged storage/myisam/mi_rlast.c: Auto merged storage/myisam/mi_rnext.c: Auto merged storage/myisam/mi_rnext_same.c: Auto merged storage/myisam/mi_rprev.c: Auto merged storage/myisam/mi_rrnd.c: Auto merged storage/myisam/mi_rsame.c: Auto merged storage/myisam/mi_rsamepos.c: Auto merged storage/myisam/mi_scan.c: Auto merged storage/myisam/mi_search.c: Auto merged storage/myisam/mi_static.c: Auto merged storage/myisam/mi_statrec.c: Auto merged storage/myisam/mi_test1.c: Auto merged storage/myisam/mi_test2.c: Auto merged storage/myisam/mi_test3.c: Auto merged storage/myisam/mi_unique.c: Auto merged storage/myisam/mi_update.c: Auto merged storage/myisam/mi_write.c: Auto merged storage/myisam/myisam_ftdump.c: Auto merged storage/myisam/myisamdef.h: Auto merged storage/myisam/myisamlog.c: Auto merged storage/myisam/myisampack.c: Auto merged storage/myisam/rt_index.c: Auto merged storage/myisam/rt_index.h: Auto merged storage/myisam/rt_key.h: Auto merged storage/myisam/rt_mbr.c: Auto merged storage/myisam/rt_mbr.h: Auto merged storage/myisam/rt_split.c: Auto merged storage/myisam/rt_test.c: Auto merged storage/myisam/sort.c: Auto merged storage/myisam/sp_defs.h: Auto merged storage/myisam/sp_test.c: Auto merged storage/myisammrg/Makefile.am: Auto merged storage/myisammrg/ha_myisammrg.cc: Auto merged storage/myisammrg/ha_myisammrg.h: Auto merged storage/myisammrg/myrg_close.c: Auto merged storage/myisammrg/myrg_create.c: Auto merged storage/myisammrg/myrg_def.h: Auto merged storage/myisammrg/myrg_delete.c: Auto merged storage/myisammrg/myrg_extra.c: Auto merged storage/myisammrg/myrg_info.c: Auto merged storage/myisammrg/myrg_locking.c: Auto merged storage/myisammrg/myrg_open.c: Auto merged storage/myisammrg/myrg_panic.c: Auto merged storage/myisammrg/myrg_queue.c: Auto merged storage/myisammrg/myrg_range.c: Auto merged storage/myisammrg/myrg_rfirst.c: Auto merged storage/myisammrg/myrg_rkey.c: Auto merged storage/myisammrg/myrg_rlast.c: Auto merged storage/myisammrg/myrg_rnext.c: Auto merged storage/myisammrg/myrg_rnext_same.c: Auto merged storage/myisammrg/myrg_rprev.c: Auto merged storage/myisammrg/myrg_rrnd.c: Auto merged storage/myisammrg/myrg_rsame.c: Auto merged storage/myisammrg/myrg_static.c: Auto merged storage/myisammrg/myrg_update.c: Auto merged storage/myisammrg/myrg_write.c: Auto merged storage/ndb/Makefile.am: Auto merged storage/ndb/config/common.mk.am: Auto merged storage/ndb/config/type_kernel.mk.am: Auto merged storage/ndb/config/type_mgmapiclient.mk.am: Auto merged storage/ndb/config/type_ndbapi.mk.am: Auto merged storage/ndb/config/type_ndbapiclient.mk.am: Auto merged storage/ndb/config/type_ndbapitest.mk.am: Auto merged storage/ndb/config/type_ndbapitools.mk.am: Auto merged storage/ndb/config/type_util.mk.am: Auto merged storage/ndb/docs/Makefile.am: Auto merged storage/ndb/include/Makefile.am: Auto merged storage/ndb/include/kernel/kernel_config_parameters.h: Auto merged storage/ndb/include/kernel/signaldata/CntrStart.hpp: Auto merged storage/ndb/include/kernel/signaldata/ReadConfig.hpp: Auto merged storage/ndb/include/kernel/signaldata/UpgradeStartup.hpp: Auto merged storage/ndb/include/logger/FileLogHandler.hpp: Auto merged storage/ndb/include/ndb_net.h: Auto merged storage/ndb/include/mgmapi/mgmapi_config_parameters.h: Auto merged storage/ndb/include/mgmapi/mgmapi_config_parameters_debug.h: Auto merged storage/ndb/include/util/ConfigValues.hpp: Auto merged storage/ndb/include/util/File.hpp: Auto merged storage/ndb/include/util/Vector.hpp: Auto merged storage/ndb/src/Makefile.am: Auto merged storage/ndb/src/common/Makefile.am: Auto merged storage/ndb/src/common/debugger/Makefile.am: Auto merged storage/ndb/src/common/debugger/signaldata/CntrStart.cpp: Auto merged storage/ndb/src/common/debugger/signaldata/Makefile.am: Auto merged storage/ndb/src/common/debugger/signaldata/ReadNodesConf.cpp: Auto merged storage/ndb/src/common/debugger/signaldata/print.awk: Auto merged storage/ndb/src/common/logger/FileLogHandler.cpp: Auto merged storage/ndb/src/common/logger/Makefile.am: Auto merged storage/ndb/src/common/mgmcommon/Makefile.am: Auto merged storage/ndb/src/common/transporter/Makefile.am: Auto merged storage/ndb/src/common/util/Bitmask.cpp: Auto merged storage/ndb/src/common/util/ConfigValues.cpp: Auto merged storage/ndb/src/common/util/File.cpp: Auto merged storage/ndb/src/common/util/Makefile.am: Auto merged storage/ndb/src/common/util/new.cpp: Auto merged storage/ndb/src/common/util/testConfigValues/testConfigValues.cpp: Auto merged storage/ndb/src/cw/Makefile.am: Auto merged storage/ndb/src/cw/cpcd/Makefile.am: Auto merged storage/ndb/src/kernel/blocks/Makefile.am: Auto merged storage/ndb/src/kernel/blocks/backup/Makefile.am: Auto merged storage/ndb/src/kernel/blocks/dbdict/Master_AddTable.sfl: Auto merged storage/ndb/src/kernel/blocks/dbdict/Slave_AddTable.sfl: Auto merged storage/ndb/src/kernel/blocks/dbtc/DbtcMain.cpp: Auto merged storage/ndb/src/kernel/error/Makefile.am: Auto merged storage/ndb/src/kernel/vm/Makefile.am: Auto merged storage/ndb/src/mgmapi/Makefile.am: Auto merged storage/ndb/src/mgmapi/mgmapi_configuration.cpp: Auto merged storage/ndb/src/mgmclient/Makefile.am: Auto merged storage/ndb/src/mgmsrv/Makefile.am: Auto merged storage/ndb/src/mgmsrv/MgmtSrvr.cpp: Auto merged storage/ndb/src/ndbapi/Makefile.am: Auto merged storage/ndb/src/ndbapi/NdbTransaction.cpp: Auto merged storage/ndb/src/ndbapi/Ndbif.cpp: Auto merged storage/ndb/test/Makefile.am: Auto merged storage/ndb/test/ndbapi/Makefile.am: Auto merged storage/ndb/test/ndbapi/bank/Makefile.am: Auto merged storage/ndb/test/ndbapi/testBasic.cpp: Auto merged storage/ndb/test/ndbapi/testIndex.cpp: Auto merged storage/ndb/test/run-test/Makefile.am: Auto merged storage/ndb/test/run-test/daily-basic-tests.txt: Auto merged storage/ndb/test/src/Makefile.am: Auto merged storage/ndb/test/tools/Makefile.am: Auto merged storage/ndb/tools/Makefile.am: Auto merged strings/Makefile.am: Auto merged strings/ctype-extra.c: Auto merged tests/Makefile.am: Auto merged vio/Makefile.am: Auto merged BitKeeper/deleted/.del-colspec-fix.pl~6c78d3332330b19e: Auto merged BitKeeper/deleted/.del-docbook-fixup.pl~46cf3bdef147084e: Auto merged BitKeeper/deleted/.del-docbook-prefix.pl~876c7d33c68c224a: Auto merged BitKeeper/deleted/.del-docbook-split~be931c3922898d0: Auto merged BitKeeper/deleted/.del-make-docbook~ccac1eb717e92ac9: Auto merged BitKeeper/deleted/.del-make-makefile~39fd454b487126e8: Auto merged BitKeeper/deleted/.del-test-make-manual-de~33cad2886311b8a: Auto merged BitKeeper/deleted/.del-test-make-manual~5da458f958a424ec: Auto merged BitKeeper/deleted/.del-xwf~76b97805d9146b80: Auto merged server-tools/instance-manager/listener.h: SCCS merged server-tools/instance-manager/manager.h: SCCS merged server-tools/instance-manager/mysql_connection.h: SCCS merged server-tools/instance-manager/priv.h: SCCS merged storage/ndb/src/kernel/blocks/dblqh/Makefile.am: SCCS merged
545 lines
16 KiB
C++
545 lines
16 KiB
C++
/* Copyright (C) 2000-2006 MySQL AB
|
|
|
|
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 */
|
|
|
|
|
|
/* Functions to handle keys and fields in forms */
|
|
|
|
#include "mysql_priv.h"
|
|
|
|
/*
|
|
Search after a key that starts with 'field'
|
|
|
|
SYNOPSIS
|
|
find_ref_key()
|
|
key First key to check
|
|
key_count How many keys to check
|
|
record Start of record
|
|
field Field to search after
|
|
key_length On partial match, contains length of fields before
|
|
field
|
|
|
|
NOTES
|
|
Used when calculating key for NEXT_NUMBER
|
|
|
|
IMPLEMENTATION
|
|
If no key starts with field test if field is part of some key. If we find
|
|
one, then return first key and set key_length to the number of bytes
|
|
preceding 'field'.
|
|
|
|
RETURN
|
|
-1 field is not part of the key
|
|
# Key part for key matching key.
|
|
key_length is set to length of key before (not including) field
|
|
*/
|
|
|
|
int find_ref_key(KEY *key, uint key_count, byte *record, Field *field,
|
|
uint *key_length)
|
|
{
|
|
reg2 int i;
|
|
reg3 KEY *key_info;
|
|
uint fieldpos;
|
|
|
|
fieldpos= field->offset(record);
|
|
|
|
/* Test if some key starts as fieldpos */
|
|
for (i= 0, key_info= key ;
|
|
i < (int) key_count ;
|
|
i++, key_info++)
|
|
{
|
|
if (key_info->key_part[0].offset == fieldpos)
|
|
{ /* Found key. Calc keylength */
|
|
*key_length=0;
|
|
return(i); /* Use this key */
|
|
}
|
|
}
|
|
|
|
/* Test if some key contains fieldpos */
|
|
for (i= 0, key_info= key;
|
|
i < (int) key_count ;
|
|
i++, key_info++)
|
|
{
|
|
uint j;
|
|
KEY_PART_INFO *key_part;
|
|
*key_length=0;
|
|
for (j=0, key_part=key_info->key_part ;
|
|
j < key_info->key_parts ;
|
|
j++, key_part++)
|
|
{
|
|
if (key_part->offset == fieldpos)
|
|
return(i); /* Use this key */
|
|
*key_length+=key_part->store_length;
|
|
}
|
|
}
|
|
return(-1); /* No key is ok */
|
|
}
|
|
|
|
|
|
/*
|
|
Copy part of a record that forms a key or key prefix to a buffer.
|
|
|
|
SYNOPSIS
|
|
key_copy()
|
|
to_key buffer that will be used as a key
|
|
from_record full record to be copied from
|
|
key_info descriptor of the index
|
|
key_length specifies length of all keyparts that will be copied
|
|
|
|
DESCRIPTION
|
|
The function takes a complete table record (as e.g. retrieved by
|
|
handler::index_read()), and a description of an index on the same table,
|
|
and extracts the first key_length bytes of the record which are part of a
|
|
key into to_key. If length == 0 then copy all bytes from the record that
|
|
form a key.
|
|
|
|
RETURN
|
|
None
|
|
*/
|
|
|
|
void key_copy(byte *to_key, byte *from_record, KEY *key_info, uint key_length)
|
|
{
|
|
uint length;
|
|
KEY_PART_INFO *key_part;
|
|
|
|
if (key_length == 0)
|
|
key_length= key_info->key_length;
|
|
for (key_part= key_info->key_part; (int) key_length > 0; key_part++)
|
|
{
|
|
if (key_part->null_bit)
|
|
{
|
|
*to_key++= test(from_record[key_part->null_offset] &
|
|
key_part->null_bit);
|
|
key_length--;
|
|
}
|
|
if (key_part->type == HA_KEYTYPE_BIT)
|
|
{
|
|
Field_bit *field= (Field_bit *) (key_part->field);
|
|
if (field->bit_len)
|
|
{
|
|
uchar bits= get_rec_bits((uchar*) from_record +
|
|
key_part->null_offset +
|
|
(key_part->null_bit == 128),
|
|
field->bit_ofs, field->bit_len);
|
|
*to_key++= bits;
|
|
key_length--;
|
|
}
|
|
}
|
|
if (key_part->key_part_flag & HA_BLOB_PART)
|
|
{
|
|
char *pos;
|
|
ulong blob_length= ((Field_blob*) key_part->field)->get_length();
|
|
key_length-= HA_KEY_BLOB_LENGTH;
|
|
((Field_blob*) key_part->field)->get_ptr(&pos);
|
|
length=min(key_length, key_part->length);
|
|
set_if_smaller(blob_length, length);
|
|
int2store(to_key, (uint) blob_length);
|
|
to_key+= HA_KEY_BLOB_LENGTH; // Skip length info
|
|
memcpy(to_key, pos, blob_length);
|
|
}
|
|
else if (key_part->key_part_flag & HA_VAR_LENGTH_PART)
|
|
{
|
|
key_length-= HA_KEY_BLOB_LENGTH;
|
|
length= min(key_length, key_part->length);
|
|
key_part->field->get_key_image((char *) to_key, length, Field::itRAW);
|
|
to_key+= HA_KEY_BLOB_LENGTH;
|
|
}
|
|
else
|
|
{
|
|
length= min(key_length, key_part->length);
|
|
memcpy(to_key, from_record + key_part->offset, (size_t) length);
|
|
}
|
|
to_key+= length;
|
|
key_length-= length;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
Restore a key from some buffer to record.
|
|
|
|
SYNOPSIS
|
|
key_restore()
|
|
to_record record buffer where the key will be restored to
|
|
from_key buffer that contains a key
|
|
key_info descriptor of the index
|
|
key_length specifies length of all keyparts that will be restored
|
|
|
|
DESCRIPTION
|
|
This function converts a key into record format. It can be used in cases
|
|
when we want to return a key as a result row.
|
|
|
|
RETURN
|
|
None
|
|
*/
|
|
|
|
void key_restore(byte *to_record, byte *from_key, KEY *key_info,
|
|
uint key_length)
|
|
{
|
|
uint length;
|
|
KEY_PART_INFO *key_part;
|
|
|
|
if (key_length == 0)
|
|
{
|
|
key_length= key_info->key_length;
|
|
}
|
|
for (key_part= key_info->key_part ; (int) key_length > 0 ; key_part++)
|
|
{
|
|
if (key_part->null_bit)
|
|
{
|
|
if (*from_key++)
|
|
to_record[key_part->null_offset]|= key_part->null_bit;
|
|
else
|
|
to_record[key_part->null_offset]&= ~key_part->null_bit;
|
|
key_length--;
|
|
}
|
|
if (key_part->type == HA_KEYTYPE_BIT)
|
|
{
|
|
Field_bit *field= (Field_bit *) (key_part->field);
|
|
if (field->bit_len)
|
|
{
|
|
uchar bits= *(from_key + key_part->length -
|
|
field->pack_length_in_rec() - 1);
|
|
set_rec_bits(bits, to_record + key_part->null_offset +
|
|
(key_part->null_bit == 128),
|
|
field->bit_ofs, field->bit_len);
|
|
}
|
|
}
|
|
if (key_part->key_part_flag & HA_BLOB_PART)
|
|
{
|
|
uint blob_length= uint2korr(from_key);
|
|
from_key+= HA_KEY_BLOB_LENGTH;
|
|
key_length-= HA_KEY_BLOB_LENGTH;
|
|
((Field_blob*) key_part->field)->set_ptr((ulong) blob_length,
|
|
(char*) from_key);
|
|
length= key_part->length;
|
|
}
|
|
else if (key_part->key_part_flag & HA_VAR_LENGTH_PART)
|
|
{
|
|
my_bitmap_map *old_map;
|
|
key_length-= HA_KEY_BLOB_LENGTH;
|
|
length= min(key_length, key_part->length);
|
|
old_map= dbug_tmp_use_all_columns(key_part->field->table,
|
|
key_part->field->table->write_set);
|
|
key_part->field->set_key_image((char *) from_key, length);
|
|
dbug_tmp_restore_column_map(key_part->field->table->write_set, old_map);
|
|
from_key+= HA_KEY_BLOB_LENGTH;
|
|
}
|
|
else
|
|
{
|
|
length= min(key_length, key_part->length);
|
|
memcpy(to_record + key_part->offset, from_key, (size_t) length);
|
|
}
|
|
from_key+= length;
|
|
key_length-= length;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
Compare if a key has changed
|
|
|
|
SYNOPSIS
|
|
key_cmp_if_same()
|
|
table TABLE
|
|
key key to compare to row
|
|
idx Index used
|
|
key_length Length of key
|
|
|
|
NOTES
|
|
In theory we could just call field->cmp() for all field types,
|
|
but as we are only interested if a key has changed (not if the key is
|
|
larger or smaller than the previous value) we can do things a bit
|
|
faster by using memcmp() instead.
|
|
|
|
RETURN
|
|
0 If key is equal
|
|
1 Key has changed
|
|
*/
|
|
|
|
bool key_cmp_if_same(TABLE *table,const byte *key,uint idx,uint key_length)
|
|
{
|
|
uint store_length;
|
|
KEY_PART_INFO *key_part;
|
|
const byte *key_end= key + key_length;;
|
|
|
|
for (key_part=table->key_info[idx].key_part;
|
|
key < key_end ;
|
|
key_part++, key+= store_length)
|
|
{
|
|
uint length;
|
|
store_length= key_part->store_length;
|
|
|
|
if (key_part->null_bit)
|
|
{
|
|
if (*key != test(table->record[0][key_part->null_offset] &
|
|
key_part->null_bit))
|
|
return 1;
|
|
if (*key)
|
|
continue;
|
|
key++;
|
|
store_length--;
|
|
}
|
|
if (key_part->key_part_flag & (HA_BLOB_PART | HA_VAR_LENGTH_PART |
|
|
HA_BIT_PART))
|
|
{
|
|
if (key_part->field->key_cmp(key, key_part->length))
|
|
return 1;
|
|
continue;
|
|
}
|
|
length= min((uint) (key_end-key), store_length);
|
|
if (!(key_part->key_type & (FIELDFLAG_NUMBER+FIELDFLAG_BINARY+
|
|
FIELDFLAG_PACK)))
|
|
{
|
|
CHARSET_INFO *cs= key_part->field->charset();
|
|
uint char_length= key_part->length / cs->mbmaxlen;
|
|
const byte *pos= table->record[0] + key_part->offset;
|
|
if (length > char_length)
|
|
{
|
|
char_length= my_charpos(cs, pos, pos + length, char_length);
|
|
set_if_smaller(char_length, length);
|
|
}
|
|
if (cs->coll->strnncollsp(cs,
|
|
(const uchar*) key, length,
|
|
(const uchar*) pos, char_length, 0))
|
|
return 1;
|
|
continue;
|
|
}
|
|
if (memcmp(key,table->record[0]+key_part->offset,length))
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
unpack key-fields from record to some buffer
|
|
|
|
SYNOPSIS
|
|
key_unpack()
|
|
to Store value here in an easy to read form
|
|
table Table to use
|
|
idx Key number
|
|
|
|
NOTES
|
|
This is used mainly to get a good error message
|
|
We temporary change the column bitmap so that all columns are readable.
|
|
*/
|
|
|
|
void key_unpack(String *to,TABLE *table,uint idx)
|
|
{
|
|
KEY_PART_INFO *key_part,*key_part_end;
|
|
Field *field;
|
|
String tmp;
|
|
my_bitmap_map *old_map= dbug_tmp_use_all_columns(table, table->read_set);
|
|
DBUG_ENTER("key_unpack");
|
|
|
|
to->length(0);
|
|
for (key_part=table->key_info[idx].key_part,key_part_end=key_part+
|
|
table->key_info[idx].key_parts ;
|
|
key_part < key_part_end;
|
|
key_part++)
|
|
{
|
|
if (to->length())
|
|
to->append('-');
|
|
if (key_part->null_bit)
|
|
{
|
|
if (table->record[0][key_part->null_offset] & key_part->null_bit)
|
|
{
|
|
to->append(STRING_WITH_LEN("NULL"));
|
|
continue;
|
|
}
|
|
}
|
|
if ((field=key_part->field))
|
|
{
|
|
field->val_str(&tmp);
|
|
if (key_part->length < field->pack_length())
|
|
tmp.length(min(tmp.length(),key_part->length));
|
|
to->append(tmp);
|
|
}
|
|
else
|
|
to->append(STRING_WITH_LEN("???"));
|
|
}
|
|
dbug_tmp_restore_column_map(table->read_set, old_map);
|
|
DBUG_VOID_RETURN;
|
|
}
|
|
|
|
|
|
/*
|
|
Check if key uses field that is marked in passed field bitmap.
|
|
|
|
SYNOPSIS
|
|
is_key_used()
|
|
table TABLE object with which keys and fields are associated.
|
|
idx Key to be checked.
|
|
fields Bitmap of fields to be checked.
|
|
|
|
NOTE
|
|
This function uses TABLE::tmp_set bitmap so the caller should care
|
|
about saving/restoring its state if it also uses this bitmap.
|
|
|
|
RETURN VALUE
|
|
TRUE Key uses field from bitmap
|
|
FALSE Otherwise
|
|
*/
|
|
|
|
bool is_key_used(TABLE *table, uint idx, const MY_BITMAP *fields)
|
|
{
|
|
bitmap_clear_all(&table->tmp_set);
|
|
table->mark_columns_used_by_index_no_reset(idx, &table->tmp_set);
|
|
if (bitmap_is_overlapping(&table->tmp_set, fields))
|
|
return 1;
|
|
|
|
/*
|
|
If table handler has primary key as part of the index, check that primary
|
|
key is not updated
|
|
*/
|
|
if (idx != table->s->primary_key && table->s->primary_key < MAX_KEY &&
|
|
(table->file->ha_table_flags() & HA_PRIMARY_KEY_IN_READ_INDEX))
|
|
return is_key_used(table, table->s->primary_key, fields);
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*
|
|
Compare key in row to a given key
|
|
|
|
SYNOPSIS
|
|
key_cmp()
|
|
key_part Key part handler
|
|
key Key to compare to value in table->record[0]
|
|
key_length length of 'key'
|
|
|
|
RETURN
|
|
The return value is SIGN(key_in_row - range_key):
|
|
|
|
0 Key is equal to range or 'range' == 0 (no range)
|
|
-1 Key is less than range
|
|
1 Key is larger than range
|
|
*/
|
|
|
|
int key_cmp(KEY_PART_INFO *key_part, const byte *key, uint key_length)
|
|
{
|
|
uint store_length;
|
|
|
|
for (const byte *end=key + key_length;
|
|
key < end;
|
|
key+= store_length, key_part++)
|
|
{
|
|
int cmp;
|
|
store_length= key_part->store_length;
|
|
if (key_part->null_bit)
|
|
{
|
|
/* This key part allows null values; NULL is lower than everything */
|
|
register bool field_is_null= key_part->field->is_null();
|
|
if (*key) // If range key is null
|
|
{
|
|
/* the range is expecting a null value */
|
|
if (!field_is_null)
|
|
return 1; // Found key is > range
|
|
/* null -- exact match, go to next key part */
|
|
continue;
|
|
}
|
|
else if (field_is_null)
|
|
return -1; // NULL is less than any value
|
|
key++; // Skip null byte
|
|
store_length--;
|
|
}
|
|
if ((cmp=key_part->field->key_cmp((byte*) key, key_part->length)) < 0)
|
|
return -1;
|
|
if (cmp > 0)
|
|
return 1;
|
|
}
|
|
return 0; // Keys are equal
|
|
}
|
|
|
|
|
|
/*
|
|
Compare two records in index order
|
|
SYNOPSIS
|
|
key_rec_cmp()
|
|
key Index information
|
|
rec0 Pointer to table->record[0]
|
|
first_rec Pointer to record compare with
|
|
second_rec Pointer to record compare against first_rec
|
|
DESCRIPTION
|
|
This method is set-up such that it can be called directly from the
|
|
priority queue and it is attempted to be optimised as much as possible
|
|
since this will be called O(N * log N) times while performing a merge
|
|
sort in various places in the code.
|
|
|
|
We retrieve the pointer to table->record[0] using the fact that key_parts
|
|
have an offset making it possible to calculate the start of the record.
|
|
We need to get the diff to the compared record since none of the records
|
|
being compared are stored in table->record[0].
|
|
|
|
We first check for NULL values, if there are no NULL values we use
|
|
a compare method that gets two field pointers and a max length
|
|
and return the result of the comparison.
|
|
*/
|
|
|
|
int key_rec_cmp(void *key, byte *first_rec, byte *second_rec)
|
|
{
|
|
KEY *key_info= (KEY*)key;
|
|
uint key_parts= key_info->key_parts, i= 0;
|
|
KEY_PART_INFO *key_part= key_info->key_part;
|
|
char *rec0= key_part->field->ptr - key_part->offset;
|
|
my_ptrdiff_t first_diff= first_rec - (byte*)rec0, sec_diff= second_rec - (byte*)rec0;
|
|
int result= 0;
|
|
DBUG_ENTER("key_rec_cmp");
|
|
|
|
do
|
|
{
|
|
Field *field= key_part->field;
|
|
|
|
if (key_part->null_bit)
|
|
{
|
|
/* The key_part can contain NULL values */
|
|
bool first_is_null= field->is_null_in_record_with_offset(first_diff);
|
|
bool sec_is_null= field->is_null_in_record_with_offset(sec_diff);
|
|
/*
|
|
NULL is smaller then everything so if first is NULL and the other
|
|
not then we know that we should return -1 and for the opposite
|
|
we should return +1. If both are NULL then we call it equality
|
|
although it is a strange form of equality, we have equally little
|
|
information of the real value.
|
|
*/
|
|
if (!first_is_null)
|
|
{
|
|
if (!sec_is_null)
|
|
; /* Fall through, no NULL fields */
|
|
else
|
|
{
|
|
DBUG_RETURN(+1);
|
|
}
|
|
}
|
|
else if (!sec_is_null)
|
|
{
|
|
DBUG_RETURN(-1);
|
|
}
|
|
else
|
|
goto next_loop; /* Both were NULL */
|
|
}
|
|
/*
|
|
No null values in the fields
|
|
We use the virtual method cmp_max with a max length parameter.
|
|
For most field types this translates into a cmp without
|
|
max length. The exceptions are the BLOB and VARCHAR field types
|
|
that take the max length into account.
|
|
*/
|
|
result= field->cmp_max(field->ptr+first_diff, field->ptr+sec_diff,
|
|
key_part->length);
|
|
next_loop:
|
|
key_part++;
|
|
} while (!result && ++i < key_parts);
|
|
DBUG_RETURN(result);
|
|
}
|