2003-02-04 20:52:14 +01:00
|
|
|
/* Copyright (C) 2000-2003 MySQL AB
|
2000-10-10 21:31:00 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
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; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
2000-10-10 21:31:00 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
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.
|
2000-10-10 21:31:00 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
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 */
|
|
|
|
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
/*
|
|
|
|
Mostly this file is used in the server. But a little part of it is used in
|
|
|
|
mysqlbinlog too (definition of SELECT_DISTINCT and others).
|
|
|
|
The consequence is that 90% of the file is wrapped in #ifndef MYSQL_CLIENT,
|
|
|
|
except the part which must be in the server and in the client.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
|
|
|
2001-09-14 01:54:33 +02:00
|
|
|
#include <my_global.h>
|
2002-07-23 17:31:22 +02:00
|
|
|
#include <mysql_version.h>
|
|
|
|
#include <mysql_embed.h>
|
2000-07-31 21:29:14 +02:00
|
|
|
#include <my_sys.h>
|
2004-06-24 17:08:36 +02:00
|
|
|
#include <my_time.h>
|
2000-07-31 21:29:14 +02:00
|
|
|
#include <m_string.h>
|
|
|
|
#include <hash.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <thr_lock.h>
|
|
|
|
#include <my_base.h> /* Needed by field.h */
|
2003-11-12 09:38:46 +01:00
|
|
|
#include "sql_bitmap.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2001-08-22 00:45:07 +02:00
|
|
|
#ifdef __EMX__
|
2002-07-17 14:17:20 +02:00
|
|
|
#undef write /* remove pthread.h macro definition for EMX */
|
2001-08-22 00:45:07 +02:00
|
|
|
#endif
|
2000-11-28 03:47:47 +01:00
|
|
|
|
2003-10-11 13:06:55 +02:00
|
|
|
/* TODO convert all these three maps to Bitmap classes */
|
|
|
|
typedef ulonglong table_map; /* Used for table bits in join */
|
|
|
|
typedef Bitmap<64> key_map; /* Used for finding keys */
|
|
|
|
typedef ulong key_part_map; /* Used for finding key parts */
|
|
|
|
|
2005-03-19 01:12:25 +01:00
|
|
|
/* query_id */
|
|
|
|
typedef ulonglong query_id_t;
|
|
|
|
extern query_id_t query_id;
|
|
|
|
|
|
|
|
/* increment query_id and return it. */
|
|
|
|
inline query_id_t next_query_id() { return query_id++; }
|
|
|
|
|
2003-10-11 13:06:55 +02:00
|
|
|
/* useful constants */
|
|
|
|
extern const key_map key_map_empty;
|
2005-06-03 22:46:03 +02:00
|
|
|
extern key_map key_map_full; /* Should be threaded as const */
|
2004-01-14 13:01:55 +01:00
|
|
|
extern const char *primary_key_name;
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
#include "mysql_com.h"
|
2001-05-31 16:42:37 +02:00
|
|
|
#include <violite.h>
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "unireg.h"
|
|
|
|
|
2000-09-12 02:02:33 +02:00
|
|
|
void init_sql_alloc(MEM_ROOT *root, uint block_size, uint pre_alloc_size);
|
2000-07-31 21:29:14 +02:00
|
|
|
gptr sql_alloc(unsigned size);
|
|
|
|
gptr sql_calloc(unsigned size);
|
|
|
|
char *sql_strdup(const char *str);
|
|
|
|
char *sql_strmake(const char *str,uint len);
|
|
|
|
gptr sql_memdup(const void * ptr,unsigned size);
|
|
|
|
void sql_element_free(void *ptr);
|
2003-05-21 20:39:58 +02:00
|
|
|
char *sql_strmake_with_convert(const char *str, uint32 arg_length,
|
|
|
|
CHARSET_INFO *from_cs,
|
|
|
|
uint32 max_res_length,
|
|
|
|
CHARSET_INFO *to_cs, uint32 *result_length);
|
2003-07-09 17:07:12 +02:00
|
|
|
void kill_one_thread(THD *thd, ulong id, bool only_kill_query);
|
2002-06-11 10:20:31 +02:00
|
|
|
bool net_request_file(NET* net, const char* fname);
|
2001-07-08 03:15:41 +02:00
|
|
|
char* query_table_status(THD *thd,const char *db,const char *table_name);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
#define x_free(A) { my_free((gptr) (A),MYF(MY_WME | MY_FAE | MY_ALLOW_ZERO_PTR)); }
|
|
|
|
#define safeFree(x) { if(x) { my_free((gptr) x,MYF(0)); x = NULL; } }
|
|
|
|
#define PREV_BITS(type,A) ((type) (((type) 1 << (A)) -1))
|
|
|
|
#define all_bits_set(A,B) ((A) & (B) != (B))
|
|
|
|
|
2003-06-04 17:28:51 +02:00
|
|
|
extern CHARSET_INFO *system_charset_info, *files_charset_info ;
|
|
|
|
extern CHARSET_INFO *national_charset_info, *table_alias_charset;
|
2002-10-30 13:19:43 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/***************************************************************************
|
2000-10-10 21:31:00 +02:00
|
|
|
Configuration parameters
|
2000-07-31 21:29:14 +02:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#define ACL_CACHE_SIZE 256
|
2003-07-04 02:18:15 +02:00
|
|
|
#define MAX_PASSWORD_LENGTH 32
|
2000-07-31 21:29:14 +02:00
|
|
|
#define HOST_CACHE_SIZE 128
|
|
|
|
#define MAX_ACCEPT_RETRY 10 // Test accept this many times
|
|
|
|
#define MAX_FIELDS_BEFORE_HASH 32
|
|
|
|
#define USER_VARS_HASH_SIZE 16
|
|
|
|
#define STACK_MIN_SIZE 8192 // Abort if less stack during eval.
|
2005-06-05 16:01:20 +02:00
|
|
|
#define STACK_BUFF_ALLOC 256 // For stack overrun checks
|
2000-07-31 21:29:14 +02:00
|
|
|
#ifndef MYSQLD_NET_RETRY_COUNT
|
|
|
|
#define MYSQLD_NET_RETRY_COUNT 10 // Abort read after this many int.
|
|
|
|
#endif
|
2001-01-27 10:24:05 +01:00
|
|
|
#define TEMP_POOL_SIZE 128
|
2003-10-11 21:00:24 +02:00
|
|
|
|
|
|
|
#define QUERY_ALLOC_BLOCK_SIZE 8192
|
|
|
|
#define QUERY_ALLOC_PREALLOC_SIZE 8192
|
|
|
|
#define TRANS_ALLOC_BLOCK_SIZE 4096
|
|
|
|
#define TRANS_ALLOC_PREALLOC_SIZE 4096
|
|
|
|
#define RANGE_ALLOC_BLOCK_SIZE 2048
|
|
|
|
#define ACL_ALLOC_BLOCK_SIZE 1024
|
|
|
|
#define UDF_ALLOC_BLOCK_SIZE 1024
|
|
|
|
#define TABLE_ALLOC_BLOCK_SIZE 1024
|
2003-10-15 21:40:36 +02:00
|
|
|
#define BDB_LOG_ALLOC_BLOCK_SIZE 1024
|
|
|
|
#define WARN_ALLOC_BLOCK_SIZE 2048
|
|
|
|
#define WARN_ALLOC_PREALLOC_SIZE 1024
|
2003-10-11 21:00:24 +02:00
|
|
|
|
2002-04-18 17:24:14 +02:00
|
|
|
/*
|
|
|
|
The following parameters is to decide when to use an extra cache to
|
2002-06-12 14:04:18 +02:00
|
|
|
optimise seeks when reading a big table in sorted order
|
2002-04-18 17:24:14 +02:00
|
|
|
*/
|
2005-04-07 18:24:14 +02:00
|
|
|
#define MIN_FILE_LENGTH_TO_USE_ROW_CACHE (10L*1024*1024)
|
2000-07-31 21:29:14 +02:00
|
|
|
#define MIN_ROWS_TO_USE_TABLE_CACHE 100
|
2002-11-20 21:56:57 +01:00
|
|
|
#define MIN_ROWS_TO_USE_BULK_INSERT 100
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2002-04-18 17:24:14 +02:00
|
|
|
/*
|
|
|
|
The following is used to decide if MySQL should use table scanning
|
|
|
|
instead of reading with keys. The number says how many evaluation of the
|
|
|
|
WHERE clause is comparable to reading one extra row from a table.
|
|
|
|
*/
|
2000-09-14 01:39:07 +02:00
|
|
|
#define TIME_FOR_COMPARE 5 // 5 compares == one read
|
2002-04-18 17:24:14 +02:00
|
|
|
|
2003-12-18 04:08:00 +01:00
|
|
|
/*
|
|
|
|
Number of comparisons of table rowids equivalent to reading one row from a
|
|
|
|
table.
|
|
|
|
*/
|
|
|
|
#define TIME_FOR_COMPARE_ROWID (TIME_FOR_COMPARE*2)
|
|
|
|
|
|
|
|
/*
|
|
|
|
For sequential disk seeks the cost formula is:
|
|
|
|
DISK_SEEK_BASE_COST + DISK_SEEK_PROP_COST * #blocks_to_skip
|
|
|
|
|
|
|
|
The cost of average seek
|
|
|
|
DISK_SEEK_BASE_COST + DISK_SEEK_PROP_COST*BLOCKS_IN_AVG_SEEK =1.0.
|
|
|
|
*/
|
|
|
|
#define DISK_SEEK_BASE_COST ((double)0.5)
|
|
|
|
|
|
|
|
#define BLOCKS_IN_AVG_SEEK 128
|
|
|
|
|
|
|
|
#define DISK_SEEK_PROP_COST ((double)0.5/BLOCKS_IN_AVG_SEEK)
|
|
|
|
|
|
|
|
|
2002-04-18 17:24:14 +02:00
|
|
|
/*
|
|
|
|
Number of rows in a reference table when refereed through a not unique key.
|
|
|
|
This value is only used when we don't know anything about the key
|
|
|
|
distribution.
|
|
|
|
*/
|
2000-10-10 21:31:00 +02:00
|
|
|
#define MATCHING_ROWS_IN_OTHER_TABLE 10
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
/* Don't pack string keys shorter than this (if PACK_KEYS=1 isn't used) */
|
|
|
|
#define KEY_DEFAULT_PACK_LENGTH 8
|
|
|
|
|
|
|
|
/* Characters shown for the command in 'show processlist' */
|
|
|
|
#define PROCESS_LIST_WIDTH 100
|
|
|
|
|
|
|
|
/* Time handling defaults */
|
|
|
|
#define TIMESTAMP_MAX_YEAR 2038
|
|
|
|
#define YY_PART_YEAR 70
|
2004-01-30 17:15:11 +01:00
|
|
|
#define TIMESTAMP_MIN_YEAR (1900 + YY_PART_YEAR - 1)
|
|
|
|
#define TIMESTAMP_MAX_VALUE 2145916799
|
|
|
|
#define TIMESTAMP_MIN_VALUE 1
|
2000-07-31 21:29:14 +02:00
|
|
|
#define PRECISION_FOR_DOUBLE 53
|
|
|
|
#define PRECISION_FOR_FLOAT 24
|
|
|
|
|
|
|
|
/* The following can also be changed from the command line */
|
|
|
|
#define CONNECT_TIMEOUT 5 // Do not wait long for connect
|
|
|
|
#define DEFAULT_CONCURRENCY 10
|
|
|
|
#define DELAYED_LIMIT 100 /* pause after xxx inserts */
|
|
|
|
#define DELAYED_QUEUE_SIZE 1000
|
|
|
|
#define DELAYED_WAIT_TIMEOUT 5*60 /* Wait for delayed insert */
|
|
|
|
#define FLUSH_TIME 0 /* Don't flush tables */
|
|
|
|
#define MAX_CONNECT_ERRORS 10 // errors before disabling host
|
|
|
|
|
2005-02-24 17:55:20 +01:00
|
|
|
#ifdef HAVE_INNOBASE_DB
|
|
|
|
#define IF_INNOBASE_DB(A, B) (A)
|
|
|
|
#else
|
|
|
|
#define IF_INNOBASE_DB(A, B) (B)
|
|
|
|
#endif
|
2005-05-06 10:39:30 +02:00
|
|
|
#ifdef __NETWARE__
|
|
|
|
#define IF_NETWARE(A,B) (A)
|
|
|
|
#else
|
|
|
|
#define IF_NETWARE(A,B) (B)
|
|
|
|
#endif
|
2005-02-24 17:55:20 +01:00
|
|
|
|
2001-08-22 00:45:07 +02:00
|
|
|
#if defined(__WIN__) || defined(OS2)
|
2000-07-31 21:29:14 +02:00
|
|
|
#define IF_WIN(A,B) (A)
|
|
|
|
#undef FLUSH_TIME
|
|
|
|
#define FLUSH_TIME 1800 /* Flush every half hour */
|
|
|
|
|
|
|
|
#define INTERRUPT_PRIOR -2
|
|
|
|
#define CONNECT_PRIOR -1
|
|
|
|
#define WAIT_PRIOR 0
|
|
|
|
#define QUERY_PRIOR 2
|
|
|
|
#else
|
|
|
|
#define IF_WIN(A,B) (B)
|
|
|
|
#define INTERRUPT_PRIOR 10
|
|
|
|
#define CONNECT_PRIOR 9
|
|
|
|
#define WAIT_PRIOR 8
|
|
|
|
#define QUERY_PRIOR 6
|
|
|
|
#endif /* __WIN92__ */
|
|
|
|
|
2000-12-24 14:19:00 +01:00
|
|
|
/* Bits from testflag */
|
2000-07-31 21:29:14 +02:00
|
|
|
#define TEST_PRINT_CACHED_TABLES 1
|
|
|
|
#define TEST_NO_KEY_GROUP 2
|
|
|
|
#define TEST_MIT_THREAD 4
|
|
|
|
#define TEST_BLOCKING 8
|
|
|
|
#define TEST_KEEP_TMP_TABLES 16
|
|
|
|
#define TEST_NO_THREADS 32 /* For debugging under Linux */
|
|
|
|
#define TEST_READCHECK 64 /* Force use of readcheck */
|
|
|
|
#define TEST_NO_EXTRA 128
|
2000-08-30 05:05:12 +02:00
|
|
|
#define TEST_CORE_ON_SIGNAL 256 /* Give core if signal */
|
2001-03-07 22:50:44 +01:00
|
|
|
#define TEST_NO_STACKTRACE 512
|
2003-06-10 20:42:29 +02:00
|
|
|
#define TEST_SIGINT 1024 /* Allow sigint on threads */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define TEST_SYNCHRONIZATION 2048 /* get server to do sleep in
|
|
|
|
some places */
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
#endif
|
|
|
|
|
2005-06-09 15:48:57 +02:00
|
|
|
/*
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
This is included in the server and in the client.
|
|
|
|
Options for select set by the yacc parser (stored in lex->options).
|
2005-06-09 15:48:57 +02:00
|
|
|
|
|
|
|
XXX:
|
|
|
|
log_event.h defines OPTIONS_WRITTEN_TO_BIN_LOG to specify what THD
|
|
|
|
options list are written into binlog. These options can NOT change their
|
|
|
|
values, or it will break replication between version.
|
|
|
|
|
|
|
|
context is encoded as following:
|
|
|
|
SELECT - SELECT_LEX_NODE::options
|
|
|
|
THD - THD::options
|
|
|
|
intern - neither. used only as
|
|
|
|
func(..., select_node->options | thd->options | OPTION_XXX, ...)
|
|
|
|
|
|
|
|
TODO: separate three contexts above, move them to separate bitfields.
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
*/
|
|
|
|
|
2005-06-09 15:48:57 +02:00
|
|
|
#define SELECT_DISTINCT (1L << 0) // SELECT, user
|
|
|
|
#define SELECT_STRAIGHT_JOIN (1L << 1) // SELECT, user
|
|
|
|
#define SELECT_DESCRIBE (1L << 2) // SELECT, user
|
|
|
|
#define SELECT_SMALL_RESULT (1L << 3) // SELECT, user
|
|
|
|
#define SELECT_BIG_RESULT (1L << 4) // SELECT, user
|
|
|
|
#define OPTION_FOUND_ROWS (1L << 5) // SELECT, user
|
|
|
|
#define OPTION_TO_QUERY_CACHE (1L << 6) // SELECT, user
|
|
|
|
#define SELECT_NO_JOIN_CACHE (1L << 7) // intern
|
|
|
|
#define OPTION_BIG_TABLES (1L << 8) // THD, user
|
|
|
|
#define OPTION_BIG_SELECTS (1L << 9) // THD, user
|
|
|
|
#define OPTION_LOG_OFF (1L << 10) // THD, user
|
|
|
|
#define OPTION_UPDATE_LOG (1L << 11) // THD, user, unused
|
|
|
|
#define TMP_TABLE_ALL_COLUMNS (1L << 12) // SELECT, intern
|
|
|
|
#define OPTION_WARNINGS (1L << 13) // THD, user
|
|
|
|
#define OPTION_AUTO_IS_NULL (1L << 14) // THD, user, binlog
|
|
|
|
#define OPTION_FOUND_COMMENT (1L << 15) // SELECT, intern, parser
|
|
|
|
#define OPTION_SAFE_UPDATES (1L << 16) // THD, user
|
|
|
|
#define OPTION_BUFFER_RESULT (1L << 17) // SELECT, user
|
|
|
|
#define OPTION_BIN_LOG (1L << 18) // THD, user
|
|
|
|
#define OPTION_NOT_AUTOCOMMIT (1L << 19) // THD, user
|
|
|
|
#define OPTION_BEGIN (1L << 20) // THD, intern
|
|
|
|
#define OPTION_TABLE_LOCK (1L << 21) // THD, intern
|
|
|
|
#define OPTION_QUICK (1L << 22) // SELECT (for DELETE)
|
|
|
|
#define OPTION_QUOTE_SHOW_CREATE (1L << 23) // THD, user
|
|
|
|
|
|
|
|
/* Thr following is used to detect a conflict with DISTINCT
|
|
|
|
in the user query has requested */
|
|
|
|
#define SELECT_ALL (1L << 24) // SELECT, user, parser
|
2003-10-16 14:54:47 +02:00
|
|
|
|
2000-11-24 00:51:18 +01:00
|
|
|
/* Set if we are updating a non-transaction safe table */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define OPTION_STATUS_NO_TRANS_UPDATE (1L << 25) // THD, intern
|
2000-11-24 00:51:18 +01:00
|
|
|
|
2002-06-22 19:23:53 +02:00
|
|
|
/* The following can be set when importing tables in a 'wrong order'
|
|
|
|
to suppress foreign key checks */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define OPTION_NO_FOREIGN_KEY_CHECKS (1L << 26) // THD, user, binlog
|
2002-06-22 19:23:53 +02:00
|
|
|
/* The following speeds up inserts to InnoDB tables by suppressing unique
|
|
|
|
key checks in some cases */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define OPTION_RELAXED_UNIQUE_CHECKS (1L << 27) // THD, user, binlog
|
|
|
|
#define SELECT_NO_UNLOCK (1L << 28) // SELECT, intern
|
|
|
|
#define OPTION_SCHEMA_TABLE (1L << 29) // SELECT, intern
|
2005-01-03 20:04:33 +01:00
|
|
|
/* Flag set if setup_tables already done */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define OPTION_SETUP_TABLES_DONE (1L << 30) // intern
|
|
|
|
/* If not set then the thread will ignore all warnings with level notes. */
|
|
|
|
#define OPTION_SQL_NOTES (1L << 31) // THD, user
|
2005-08-12 12:54:42 +02:00
|
|
|
/*
|
|
|
|
Force the used temporary table to be a MyISAM table (because we will use
|
|
|
|
fulltext functions when reading from it.
|
|
|
|
*/
|
|
|
|
#define TMP_TABLE_FORCE_MYISAM (LL(1) << 32)
|
2003-12-06 23:21:09 +01:00
|
|
|
|
2005-06-09 15:48:57 +02:00
|
|
|
/*
|
|
|
|
Maximum length of time zone name that we support
|
2005-03-22 00:26:12 +01:00
|
|
|
(Time zone name is char(64) in db). mysqlbinlog needs it.
|
|
|
|
*/
|
|
|
|
#define MAX_TIME_ZONE_NAME_LENGTH 72
|
|
|
|
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
/* The rest of the file is included in the server only */
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
|
|
|
2002-02-14 17:10:44 +01:00
|
|
|
/* Bits for different SQL modes modes (including ANSI mode) */
|
2005-06-09 15:48:57 +02:00
|
|
|
#define MODE_REAL_AS_FLOAT 1
|
|
|
|
#define MODE_PIPES_AS_CONCAT 2
|
|
|
|
#define MODE_ANSI_QUOTES 4
|
2002-01-30 14:32:48 +01:00
|
|
|
#define MODE_IGNORE_SPACE 8
|
2003-06-04 17:28:51 +02:00
|
|
|
#define MODE_NOT_USED 16
|
2002-01-30 14:32:48 +01:00
|
|
|
#define MODE_ONLY_FULL_GROUP_BY 32
|
|
|
|
#define MODE_NO_UNSIGNED_SUBTRACTION 64
|
2003-08-23 11:25:39 +02:00
|
|
|
#define MODE_NO_DIR_IN_CREATE 128
|
2003-08-29 12:44:35 +02:00
|
|
|
#define MODE_POSTGRESQL 256
|
|
|
|
#define MODE_ORACLE 512
|
|
|
|
#define MODE_MSSQL 1024
|
|
|
|
#define MODE_DB2 2048
|
2003-10-15 11:50:36 +02:00
|
|
|
#define MODE_MAXDB 4096
|
2003-08-29 12:44:35 +02:00
|
|
|
#define MODE_NO_KEY_OPTIONS 8192
|
2004-09-28 19:08:00 +02:00
|
|
|
#define MODE_NO_TABLE_OPTIONS 16384
|
|
|
|
#define MODE_NO_FIELD_OPTIONS 32768
|
|
|
|
#define MODE_MYSQL323 65536
|
|
|
|
#define MODE_MYSQL40 (MODE_MYSQL323*2)
|
|
|
|
#define MODE_ANSI (MODE_MYSQL40*2)
|
|
|
|
#define MODE_NO_AUTO_VALUE_ON_ZERO (MODE_ANSI*2)
|
|
|
|
#define MODE_NO_BACKSLASH_ESCAPES (MODE_NO_AUTO_VALUE_ON_ZERO*2)
|
|
|
|
#define MODE_STRICT_TRANS_TABLES (MODE_NO_BACKSLASH_ESCAPES*2)
|
|
|
|
#define MODE_STRICT_ALL_TABLES (MODE_STRICT_TRANS_TABLES*2)
|
|
|
|
#define MODE_NO_ZERO_IN_DATE (MODE_STRICT_ALL_TABLES*2)
|
|
|
|
#define MODE_NO_ZERO_DATE (MODE_NO_ZERO_IN_DATE*2)
|
|
|
|
#define MODE_INVALID_DATES (MODE_NO_ZERO_DATE*2)
|
|
|
|
#define MODE_ERROR_FOR_DIVISION_BY_ZERO (MODE_INVALID_DATES*2)
|
|
|
|
#define MODE_TRADITIONAL (MODE_ERROR_FOR_DIVISION_BY_ZERO*2)
|
2004-11-02 15:45:26 +01:00
|
|
|
#define MODE_NO_AUTO_CREATE_USER (MODE_TRADITIONAL*2)
|
2004-11-27 20:26:46 +01:00
|
|
|
#define MODE_HIGH_NOT_PRECEDENCE (MODE_NO_AUTO_CREATE_USER*2)
|
2005-06-17 23:14:44 +02:00
|
|
|
#define MODE_NO_ENGINE_SUBSTITUTION (MODE_HIGH_NOT_PRECEDENCE*2)
|
2005-02-03 16:22:16 +01:00
|
|
|
/*
|
|
|
|
Replication uses 8 bytes to store SQL_MODE in the binary log. The day you
|
|
|
|
use strictly more than 64 bits by adding one more define above, you should
|
|
|
|
contact the replication team because the replication code should then be
|
|
|
|
updated (to store more bytes on disk).
|
2005-03-09 02:40:43 +01:00
|
|
|
|
|
|
|
NOTE: When adding new SQL_MODE types, make sure to also add them to
|
|
|
|
../scripts/mysql_create_system_tables.sh and
|
|
|
|
../scripts/mysql_fix_privilege_tables.sql
|
2005-02-03 16:22:16 +01:00
|
|
|
*/
|
2001-08-09 17:51:38 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
#define RAID_BLOCK_SIZE 1024
|
|
|
|
|
2003-07-08 12:06:05 +02:00
|
|
|
#define MY_CHARSET_BIN_MB_MAXLEN 1
|
|
|
|
|
2003-11-17 19:53:40 +01:00
|
|
|
// uncachable cause
|
|
|
|
#define UNCACHEABLE_DEPENDENT 1
|
|
|
|
#define UNCACHEABLE_RAND 2
|
2004-02-01 19:07:44 +01:00
|
|
|
#define UNCACHEABLE_SIDEEFFECT 4
|
|
|
|
// forcing to save JOIN for explain
|
|
|
|
#define UNCACHEABLE_EXPLAIN 8
|
2005-06-07 22:34:53 +02:00
|
|
|
/* Don't evaluate subqueries in prepare even if they're not correlated */
|
|
|
|
#define UNCACHEABLE_PREPARE 16
|
2003-11-17 19:53:40 +01:00
|
|
|
|
2001-10-03 21:55:31 +02:00
|
|
|
#ifdef EXTRA_DEBUG
|
2002-06-11 10:20:31 +02:00
|
|
|
/*
|
|
|
|
Sync points allow us to force the server to reach a certain line of code
|
|
|
|
and block there until the client tells the server it is ok to go on.
|
|
|
|
The client tells the server to block with SELECT GET_LOCK()
|
|
|
|
and unblocks it with SELECT RELEASE_LOCK(). Used for debugging difficult
|
|
|
|
concurrency problems
|
|
|
|
*/
|
2001-10-03 21:55:31 +02:00
|
|
|
#define DBUG_SYNC_POINT(lock_name,lock_timeout) \
|
|
|
|
debug_sync_point(lock_name,lock_timeout)
|
|
|
|
void debug_sync_point(const char* lock_name, uint lock_timeout);
|
|
|
|
#else
|
|
|
|
#define DBUG_SYNC_POINT(lock_name,lock_timeout)
|
2002-06-11 10:20:31 +02:00
|
|
|
#endif /* EXTRA_DEBUG */
|
2001-10-03 21:55:31 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* BINLOG_DUMP options */
|
|
|
|
|
|
|
|
#define BINLOG_DUMP_NON_BLOCK 1
|
|
|
|
|
2000-12-15 12:18:52 +01:00
|
|
|
/* sql_show.cc:show_log_files() */
|
|
|
|
#define SHOW_LOG_STATUS_FREE "FREE"
|
|
|
|
#define SHOW_LOG_STATUS_INUSE "IN USE"
|
|
|
|
|
2003-01-09 01:19:14 +01:00
|
|
|
/* Options to add_table_to_list() */
|
|
|
|
#define TL_OPTION_UPDATING 1
|
|
|
|
#define TL_OPTION_FORCE_INDEX 2
|
2003-06-12 13:29:02 +02:00
|
|
|
#define TL_OPTION_IGNORE_LEAVES 4
|
2003-01-09 01:19:14 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* Some portable defines */
|
|
|
|
|
|
|
|
#define portable_sizeof_char_ptr 8
|
|
|
|
|
|
|
|
#define tmp_file_prefix "#sql" /* Prefix for tmp tables */
|
|
|
|
#define tmp_file_prefix_length 4
|
|
|
|
|
2003-12-07 12:10:21 +01:00
|
|
|
/* Flags for calc_week() function. */
|
|
|
|
#define WEEK_MONDAY_FIRST 1
|
|
|
|
#define WEEK_YEAR 2
|
|
|
|
#define WEEK_FIRST_WEEKDAY 4
|
|
|
|
|
2005-02-08 23:50:45 +01:00
|
|
|
#define STRING_BUFFER_USUAL_SIZE 80
|
|
|
|
|
2004-08-13 09:01:30 +02:00
|
|
|
enum enum_parsing_place
|
|
|
|
{
|
|
|
|
NO_MATTER,
|
|
|
|
IN_HAVING,
|
2004-08-31 20:10:57 +02:00
|
|
|
SELECT_LIST,
|
|
|
|
IN_WHERE
|
2004-08-13 09:01:30 +02:00
|
|
|
};
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
struct st_table;
|
|
|
|
class THD;
|
2004-08-21 00:02:46 +02:00
|
|
|
class Item_arena;
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
/* Struct to handle simple linked lists */
|
|
|
|
|
|
|
|
typedef struct st_sql_list {
|
|
|
|
uint elements;
|
|
|
|
byte *first;
|
|
|
|
byte **next;
|
2002-11-29 15:40:18 +01:00
|
|
|
|
|
|
|
inline void empty()
|
|
|
|
{
|
|
|
|
elements=0;
|
|
|
|
first=0;
|
|
|
|
next= &first;
|
|
|
|
}
|
|
|
|
inline void link_in_list(byte *element,byte **next_ptr)
|
|
|
|
{
|
|
|
|
elements++;
|
|
|
|
(*next)=element;
|
|
|
|
next= next_ptr;
|
|
|
|
*next=0;
|
|
|
|
}
|
2003-07-03 10:55:36 +02:00
|
|
|
inline void save_and_clear(struct st_sql_list *save)
|
|
|
|
{
|
|
|
|
*save= *this;
|
|
|
|
empty();
|
|
|
|
}
|
|
|
|
inline void push_front(struct st_sql_list *save)
|
|
|
|
{
|
|
|
|
*save->next= first; /* link current list last */
|
|
|
|
first= save->first;
|
|
|
|
elements+= save->elements;
|
|
|
|
}
|
2004-11-24 10:24:02 +01:00
|
|
|
inline void push_back(struct st_sql_list *save)
|
|
|
|
{
|
|
|
|
if (save->first)
|
|
|
|
{
|
|
|
|
*next= save->first;
|
|
|
|
next= save->next;
|
|
|
|
elements+= save->elements;
|
|
|
|
}
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
} SQL_LIST;
|
|
|
|
|
|
|
|
|
|
|
|
extern pthread_key(THD*, THR_THD);
|
|
|
|
inline THD *_current_thd(void)
|
|
|
|
{
|
|
|
|
return my_pthread_getspecific_ptr(THD*,THR_THD);
|
|
|
|
}
|
|
|
|
#define current_thd _current_thd()
|
|
|
|
|
2005-01-16 13:16:23 +01:00
|
|
|
/*
|
|
|
|
External variables
|
|
|
|
*/
|
|
|
|
extern ulong server_id, concurrency;
|
|
|
|
|
2005-02-14 21:50:09 +01:00
|
|
|
|
2004-11-24 12:56:51 +01:00
|
|
|
typedef my_bool (*qc_engine_callback)(THD *thd, char *table_key,
|
|
|
|
uint key_length,
|
|
|
|
ulonglong *engine_data);
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "sql_string.h"
|
|
|
|
#include "sql_list.h"
|
|
|
|
#include "sql_map.h"
|
2005-02-08 23:50:45 +01:00
|
|
|
#include "my_decimal.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "handler.h"
|
2004-05-11 22:23:49 +02:00
|
|
|
#include "parse_file.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "table.h"
|
2005-04-01 14:04:50 +02:00
|
|
|
#include "sql_error.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "field.h" /* Field definitions */
|
2002-12-11 08:17:51 +01:00
|
|
|
#include "protocol.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "sql_udf.h"
|
2004-06-07 10:09:10 +02:00
|
|
|
class user_var_entry;
|
2005-07-16 01:29:13 +02:00
|
|
|
enum enum_var_type
|
|
|
|
{
|
2005-07-16 14:10:42 +02:00
|
|
|
OPT_DEFAULT= 0, OPT_SESSION, OPT_GLOBAL
|
2005-07-16 01:29:13 +02:00
|
|
|
};
|
|
|
|
class sys_var;
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "item.h"
|
2005-02-08 23:50:45 +01:00
|
|
|
extern my_decimal decimal_zero;
|
2003-11-03 11:28:36 +01:00
|
|
|
typedef Comp_creator* (*chooser_compare_func_creator)(bool invert);
|
2004-02-12 02:10:26 +01:00
|
|
|
/* sql_parse.cc */
|
|
|
|
void free_items(Item *item);
|
|
|
|
void cleanup_items(Item *item);
|
2004-02-12 17:50:00 +01:00
|
|
|
class THD;
|
2005-08-08 15:46:06 +02:00
|
|
|
void close_thread_tables(THD *thd, bool locked=0, bool skip_derived=0);
|
2004-09-03 20:43:04 +02:00
|
|
|
bool check_one_table_access(THD *thd, ulong privilege,
|
2004-04-10 00:14:32 +02:00
|
|
|
TABLE_LIST *tables);
|
2005-05-17 20:54:20 +02:00
|
|
|
bool check_routine_access(THD *thd,ulong want_access,char *db,char *name,
|
|
|
|
bool is_proc, bool no_errors);
|
2004-09-03 20:43:04 +02:00
|
|
|
bool check_some_access(THD *thd, ulong want_access, TABLE_LIST *table);
|
2004-04-07 23:16:17 +02:00
|
|
|
bool check_merge_table_access(THD *thd, char *db,
|
|
|
|
TABLE_LIST *table_list);
|
2005-05-17 20:54:20 +02:00
|
|
|
bool check_some_routine_access(THD *thd, const char *db, const char *name, bool is_proc);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool multi_update_precheck(THD *thd, TABLE_LIST *tables);
|
2005-06-08 23:07:52 +02:00
|
|
|
bool multi_delete_precheck(THD *thd, TABLE_LIST *tables);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_multi_update_prepare(THD *thd);
|
|
|
|
bool mysql_multi_delete_prepare(THD *thd);
|
|
|
|
bool mysql_insert_select_prepare(THD *thd);
|
|
|
|
bool update_precheck(THD *thd, TABLE_LIST *tables);
|
|
|
|
bool delete_precheck(THD *thd, TABLE_LIST *tables);
|
2004-11-12 14:36:31 +01:00
|
|
|
bool insert_precheck(THD *thd, TABLE_LIST *tables);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool create_table_precheck(THD *thd, TABLE_LIST *tables,
|
|
|
|
TABLE_LIST *create_table);
|
2005-02-17 13:52:16 +01:00
|
|
|
|
|
|
|
enum enum_mysql_completiontype {
|
|
|
|
ROLLBACK_RELEASE=-2, ROLLBACK=1, ROLLBACK_AND_CHAIN=7,
|
|
|
|
COMMIT_RELEASE=-1, COMMIT=0, COMMIT_AND_CHAIN=6
|
|
|
|
};
|
|
|
|
|
|
|
|
int end_trans(THD *thd, enum enum_mysql_completiontype completion);
|
|
|
|
|
2004-08-31 20:10:57 +02:00
|
|
|
Item *negate_expression(THD *thd, Item *expr);
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "sql_class.h"
|
2004-12-09 11:31:46 +01:00
|
|
|
#include "sql_acl.h"
|
|
|
|
#include "tztime.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "opt_range.h"
|
2002-03-22 21:55:08 +01:00
|
|
|
|
|
|
|
#ifdef HAVE_QUERY_CACHE
|
2003-10-02 11:02:05 +02:00
|
|
|
struct Query_cache_query_flags
|
|
|
|
{
|
|
|
|
unsigned int client_long_flag:1;
|
2005-01-19 00:59:39 +01:00
|
|
|
unsigned int client_protocol_41:1;
|
2005-07-23 06:51:25 +02:00
|
|
|
unsigned int more_results_exists:1;
|
2003-10-03 14:09:54 +02:00
|
|
|
uint character_set_client_num;
|
|
|
|
uint character_set_results_num;
|
|
|
|
uint collation_connection_num;
|
2003-10-02 11:02:05 +02:00
|
|
|
ha_rows limit;
|
2004-06-18 08:11:31 +02:00
|
|
|
Time_zone *time_zone;
|
2004-09-10 15:28:18 +02:00
|
|
|
ulong sql_mode;
|
|
|
|
ulong max_sort_length;
|
|
|
|
ulong group_concat_max_len;
|
2003-10-02 11:02:05 +02:00
|
|
|
};
|
|
|
|
#define QUERY_CACHE_FLAGS_SIZE sizeof(Query_cache_query_flags)
|
2001-12-02 13:34:01 +01:00
|
|
|
#include "sql_cache.h"
|
2002-03-22 21:55:08 +01:00
|
|
|
#define query_cache_store_query(A, B) query_cache.store_query(A, B)
|
|
|
|
#define query_cache_destroy() query_cache.destroy()
|
|
|
|
#define query_cache_result_size_limit(A) query_cache.result_size_limit(A)
|
|
|
|
#define query_cache_resize(A) query_cache.resize(A)
|
2003-03-02 20:39:03 +01:00
|
|
|
#define query_cache_set_min_res_unit(A) query_cache.set_min_res_unit(A)
|
2002-03-22 21:55:08 +01:00
|
|
|
#define query_cache_invalidate3(A, B, C) query_cache.invalidate(A, B, C)
|
|
|
|
#define query_cache_invalidate1(A) query_cache.invalidate(A)
|
|
|
|
#define query_cache_send_result_to_client(A, B, C) \
|
|
|
|
query_cache.send_result_to_client(A, B, C)
|
|
|
|
#define query_cache_invalidate_by_MyISAM_filename_ref \
|
|
|
|
&query_cache_invalidate_by_MyISAM_filename
|
|
|
|
#else
|
2003-10-02 11:02:05 +02:00
|
|
|
#define QUERY_CACHE_FLAGS_SIZE 0
|
2002-03-22 21:55:08 +01:00
|
|
|
#define query_cache_store_query(A, B)
|
|
|
|
#define query_cache_destroy()
|
|
|
|
#define query_cache_result_size_limit(A)
|
|
|
|
#define query_cache_resize(A)
|
2003-03-02 20:39:03 +01:00
|
|
|
#define query_cache_set_min_res_unit(A)
|
2002-03-22 21:55:08 +01:00
|
|
|
#define query_cache_invalidate3(A, B, C)
|
|
|
|
#define query_cache_invalidate1(A)
|
|
|
|
#define query_cache_send_result_to_client(A, B, C) 0
|
|
|
|
#define query_cache_invalidate_by_MyISAM_filename_ref NULL
|
|
|
|
|
|
|
|
#define query_cache_abort(A)
|
|
|
|
#define query_cache_end_of_result(A)
|
|
|
|
#define query_cache_invalidate_by_MyISAM_filename_ref NULL
|
|
|
|
#endif /*HAVE_QUERY_CACHE*/
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_create_db(THD *thd, char *db, HA_CREATE_INFO *create, bool silent);
|
|
|
|
bool mysql_alter_db(THD *thd, const char *db, HA_CREATE_INFO *create);
|
|
|
|
bool mysql_rm_db(THD *thd,char *db,bool if_exists, bool silent);
|
2002-08-21 21:04:22 +02:00
|
|
|
void mysql_binlog_send(THD* thd, char* log_ident, my_off_t pos, ushort flags);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_rm_table(THD *thd,TABLE_LIST *tables, my_bool if_exists,
|
|
|
|
my_bool drop_temporary);
|
2001-09-02 12:47:00 +02:00
|
|
|
int mysql_rm_table_part2(THD *thd, TABLE_LIST *tables, bool if_exists,
|
2004-07-16 00:15:55 +02:00
|
|
|
bool drop_temporary, bool drop_view, bool log_query);
|
2002-07-23 17:31:22 +02:00
|
|
|
int mysql_rm_table_part2_with_lock(THD *thd, TABLE_LIST *tables,
|
2003-01-04 14:37:20 +01:00
|
|
|
bool if_exists, bool drop_temporary,
|
2002-07-23 17:31:22 +02:00
|
|
|
bool log_query);
|
2000-07-31 21:29:14 +02:00
|
|
|
int quick_rm_table(enum db_type base,const char *db,
|
|
|
|
const char *table_name);
|
2004-09-07 14:29:46 +02:00
|
|
|
void close_cached_table(THD *thd, TABLE *table);
|
2000-08-21 02:07:54 +02:00
|
|
|
bool mysql_rename_tables(THD *thd, TABLE_LIST *table_list);
|
2005-08-12 02:04:16 +02:00
|
|
|
bool mysql_change_db(THD *thd,const char *name,bool no_access_check);
|
2000-07-31 21:29:14 +02:00
|
|
|
void mysql_parse(THD *thd,char *inBuf,uint length);
|
2004-03-11 17:38:19 +01:00
|
|
|
bool mysql_test_parse_for_slave(THD *thd,char *inBuf,uint length);
|
2003-02-14 10:47:41 +01:00
|
|
|
bool is_update_query(enum enum_sql_command command);
|
2002-10-02 12:33:08 +02:00
|
|
|
bool alloc_query(THD *thd, char *packet, ulong packet_length);
|
2000-08-15 19:09:37 +02:00
|
|
|
void mysql_init_select(LEX *lex);
|
2004-10-14 00:53:59 +02:00
|
|
|
void mysql_reset_thd_for_next_command(THD *thd);
|
2004-11-03 11:39:38 +01:00
|
|
|
void mysql_init_query(THD *thd, uchar *buf, uint length);
|
2002-05-06 23:04:16 +02:00
|
|
|
bool mysql_new_select(LEX *lex, bool move_down);
|
2002-10-02 12:33:08 +02:00
|
|
|
void create_select_for_variable(const char *var_name);
|
2002-01-02 23:46:43 +01:00
|
|
|
void mysql_init_multi_delete(LEX *lex);
|
2005-06-08 23:07:52 +02:00
|
|
|
bool multi_delete_set_locks_and_link_aux_tables(LEX *lex);
|
2001-02-20 21:34:47 +01:00
|
|
|
void init_max_user_conn(void);
|
2002-09-16 14:55:19 +02:00
|
|
|
void init_update_queries(void);
|
2001-02-20 21:34:47 +01:00
|
|
|
void free_max_user_conn(void);
|
2002-11-07 02:54:00 +01:00
|
|
|
extern "C" pthread_handler_decl(handle_one_connection,arg);
|
|
|
|
extern "C" pthread_handler_decl(handle_bootstrap,arg);
|
2000-07-31 21:29:14 +02:00
|
|
|
void end_thread(THD *thd,bool put_in_cache);
|
|
|
|
void flush_thread_cache();
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_execute_command(THD *thd);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool do_command(THD *thd);
|
2001-04-11 13:04:03 +02:00
|
|
|
bool dispatch_command(enum enum_server_command command, THD *thd,
|
|
|
|
char* packet, uint packet_length);
|
2005-06-16 23:58:36 +02:00
|
|
|
void log_slow_statement(THD *thd);
|
2003-12-12 21:26:58 +01:00
|
|
|
bool check_dup(const char *db, const char *name, TABLE_LIST *tables);
|
2003-04-08 07:35:13 +02:00
|
|
|
|
2004-03-12 00:10:22 +01:00
|
|
|
bool table_cache_init(void);
|
2000-07-31 21:29:14 +02:00
|
|
|
void table_cache_free(void);
|
|
|
|
uint cached_tables(void);
|
|
|
|
void kill_mysql(void);
|
2003-05-26 18:01:20 +02:00
|
|
|
void close_connection(THD *thd, uint errcode, bool lock);
|
2003-09-26 12:33:13 +02:00
|
|
|
bool reload_acl_and_cache(THD *thd, ulong options, TABLE_LIST *tables,
|
|
|
|
bool *write_to_binlog);
|
|
|
|
bool check_access(THD *thd, ulong access, const char *db, ulong *save_priv,
|
|
|
|
bool no_grant, bool no_errors);
|
2002-06-12 14:04:18 +02:00
|
|
|
bool check_table_access(THD *thd, ulong want_access, TABLE_LIST *tables,
|
2003-09-26 12:33:13 +02:00
|
|
|
bool no_errors);
|
2002-06-12 14:04:18 +02:00
|
|
|
bool check_global_access(THD *thd, ulong want_access);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_backup_table(THD* thd, TABLE_LIST* table_list);
|
|
|
|
bool mysql_restore_table(THD* thd, TABLE_LIST* table_list);
|
|
|
|
|
|
|
|
bool mysql_checksum_table(THD* thd, TABLE_LIST* table_list,
|
|
|
|
HA_CHECK_OPT* check_opt);
|
|
|
|
bool mysql_check_table(THD* thd, TABLE_LIST* table_list,
|
|
|
|
HA_CHECK_OPT* check_opt);
|
|
|
|
bool mysql_repair_table(THD* thd, TABLE_LIST* table_list,
|
|
|
|
HA_CHECK_OPT* check_opt);
|
|
|
|
bool mysql_analyze_table(THD* thd, TABLE_LIST* table_list,
|
|
|
|
HA_CHECK_OPT* check_opt);
|
|
|
|
bool mysql_optimize_table(THD* thd, TABLE_LIST* table_list,
|
|
|
|
HA_CHECK_OPT* check_opt);
|
|
|
|
bool mysql_assign_to_keycache(THD* thd, TABLE_LIST* table_list,
|
|
|
|
LEX_STRING *key_cache_name);
|
|
|
|
bool mysql_preload_keys(THD* thd, TABLE_LIST* table_list);
|
2003-11-20 21:06:25 +01:00
|
|
|
int reassign_keycache_tables(THD* thd, KEY_CACHE *src_cache,
|
|
|
|
KEY_CACHE *dst_cache);
|
2003-06-12 13:29:02 +02:00
|
|
|
|
2005-01-16 13:16:23 +01:00
|
|
|
bool mysql_xa_recover(THD *thd);
|
|
|
|
|
2002-07-24 18:55:08 +02:00
|
|
|
bool check_simple_select();
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2000-11-11 19:27:34 +01:00
|
|
|
SORT_FIELD * make_unireg_sortorder(ORDER *order, uint *length);
|
2003-01-25 01:25:52 +01:00
|
|
|
int setup_order(THD *thd, Item **ref_pointer_array, TABLE_LIST *tables,
|
|
|
|
List<Item> &fields, List <Item> &all_fields, ORDER *order);
|
|
|
|
int setup_group(THD *thd, Item **ref_pointer_array, TABLE_LIST *tables,
|
|
|
|
List<Item> &fields, List<Item> &all_fields, ORDER *order,
|
2002-08-30 11:40:40 +02:00
|
|
|
bool *hidden_group_fields);
|
2000-11-11 19:27:34 +01:00
|
|
|
|
2005-01-03 20:04:33 +01:00
|
|
|
bool handle_select(THD *thd, LEX *lex, select_result *result,
|
|
|
|
ulong setup_tables_done_option);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_select(THD *thd, Item ***rref_pointer_array,
|
|
|
|
TABLE_LIST *tables, uint wild_num, List<Item> &list,
|
|
|
|
COND *conds, uint og_num, ORDER *order, ORDER *group,
|
|
|
|
Item *having, ORDER *proc_param, ulong select_type,
|
|
|
|
select_result *result, SELECT_LEX_UNIT *unit,
|
|
|
|
SELECT_LEX *select_lex);
|
2003-02-02 22:30:01 +01:00
|
|
|
void free_underlaid_joins(THD *thd, SELECT_LEX *select);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_explain_union(THD *thd, SELECT_LEX_UNIT *unit,
|
|
|
|
select_result *result);
|
2002-09-26 22:08:22 +02:00
|
|
|
int mysql_explain_select(THD *thd, SELECT_LEX *sl, char const *type,
|
|
|
|
select_result *result);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_union(THD *thd, LEX *lex, select_result *result,
|
2005-01-03 20:04:33 +01:00
|
|
|
SELECT_LEX_UNIT *unit, ulong setup_tables_done_option);
|
2004-11-05 16:29:47 +01:00
|
|
|
int mysql_handle_derived(LEX *lex, int (*processor)(THD *thd,
|
2004-11-12 12:28:34 +01:00
|
|
|
LEX *lex,
|
|
|
|
TABLE_LIST *table));
|
2004-11-05 16:29:47 +01:00
|
|
|
int mysql_derived_prepare(THD *thd, LEX *lex, TABLE_LIST *t);
|
|
|
|
int mysql_derived_filling(THD *thd, LEX *lex, TABLE_LIST *t);
|
2001-12-05 12:03:00 +01:00
|
|
|
Field *create_tmp_field(THD *thd, TABLE *table,Item *item, Item::Type type,
|
2003-01-28 07:38:28 +01:00
|
|
|
Item ***copy_func, Field **from_field,
|
2005-03-16 15:11:01 +01:00
|
|
|
bool group, bool modify_item,
|
2005-06-30 10:38:29 +02:00
|
|
|
bool table_cant_handle_bit_fields,
|
2005-03-16 15:11:01 +01:00
|
|
|
uint convert_blob_length);
|
2005-04-19 10:09:25 +02:00
|
|
|
void sp_prepare_create_field(THD *thd, create_field *sql_field);
|
2005-03-04 22:14:35 +01:00
|
|
|
int prepare_create_field(create_field *sql_field,
|
2005-03-16 15:11:01 +01:00
|
|
|
uint *blob_columns,
|
|
|
|
int *timestamps, int *timestamps_with_niladic,
|
2005-03-04 22:14:35 +01:00
|
|
|
uint table_flags);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_create_table(THD *thd,const char *db, const char *table_name,
|
|
|
|
HA_CREATE_INFO *create_info,
|
|
|
|
List<create_field> &fields, List<Key> &keys,
|
|
|
|
bool tmp_table, uint select_field_count);
|
2004-08-20 00:52:43 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE *create_table_from_items(THD *thd, HA_CREATE_INFO *create_info,
|
2004-07-16 00:15:55 +02:00
|
|
|
TABLE_LIST *create_table,
|
2000-07-31 21:29:14 +02:00
|
|
|
List<create_field> *extra_fields,
|
|
|
|
List<Key> *keys,
|
|
|
|
List<Item> *items,
|
2004-10-20 03:04:37 +02:00
|
|
|
MYSQL_LOCK **lock);
|
|
|
|
bool mysql_alter_table(THD *thd, char *new_db, char *new_name,
|
|
|
|
HA_CREATE_INFO *create_info,
|
|
|
|
TABLE_LIST *table_list,
|
|
|
|
List<create_field> &fields,
|
|
|
|
List<Key> &keys,
|
|
|
|
uint order_num, ORDER *order,
|
|
|
|
enum enum_duplicates handle_duplicates,
|
2005-01-03 22:04:52 +01:00
|
|
|
bool ignore,
|
2005-03-16 15:11:01 +01:00
|
|
|
ALTER_INFO *alter_info, bool do_send_ok);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_recreate_table(THD *thd, TABLE_LIST *table_list, bool do_send_ok);
|
|
|
|
bool mysql_create_like_table(THD *thd, TABLE_LIST *table,
|
|
|
|
HA_CREATE_INFO *create_info,
|
|
|
|
Table_ident *src_table);
|
2000-08-21 02:07:54 +02:00
|
|
|
bool mysql_rename_table(enum db_type base,
|
|
|
|
const char *old_db,
|
|
|
|
const char * old_name,
|
|
|
|
const char *new_db,
|
|
|
|
const char * new_name);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_create_index(THD *thd, TABLE_LIST *table_list, List<Key> &keys);
|
|
|
|
bool mysql_drop_index(THD *thd, TABLE_LIST *table_list,
|
|
|
|
ALTER_INFO *alter_info);
|
2004-11-12 13:34:00 +01:00
|
|
|
bool mysql_prepare_update(THD *thd, TABLE_LIST *table_list,
|
|
|
|
Item **conds, uint order_num, ORDER *order);
|
2004-11-25 01:23:13 +01:00
|
|
|
int mysql_update(THD *thd,TABLE_LIST *tables,List<Item> &fields,
|
|
|
|
List<Item> &values,COND *conds,
|
|
|
|
uint order_num, ORDER *order, ha_rows limit,
|
2004-12-31 11:04:35 +01:00
|
|
|
enum enum_duplicates handle_duplicates, bool ignore);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_multi_update(THD *thd, TABLE_LIST *table_list,
|
|
|
|
List<Item> *fields, List<Item> *values,
|
2005-08-12 12:54:42 +02:00
|
|
|
COND *conds, ulonglong options,
|
2005-01-03 22:04:52 +01:00
|
|
|
enum enum_duplicates handle_duplicates, bool ignore,
|
2004-10-20 03:04:37 +02:00
|
|
|
SELECT_LEX_UNIT *unit, SELECT_LEX *select_lex);
|
2005-07-04 02:24:25 +02:00
|
|
|
bool mysql_prepare_insert(THD *thd, TABLE_LIST *table_list, TABLE *table,
|
2004-10-20 03:04:37 +02:00
|
|
|
List<Item> &fields, List_item *values,
|
|
|
|
List<Item> &update_fields,
|
2004-12-30 23:44:00 +01:00
|
|
|
List<Item> &update_values, enum_duplicates duplic,
|
|
|
|
COND **where, bool select_insert);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_insert(THD *thd,TABLE_LIST *table,List<Item> &fields,
|
|
|
|
List<List_item> &values, List<Item> &update_fields,
|
2005-01-03 22:04:52 +01:00
|
|
|
List<Item> &update_values, enum_duplicates flag,
|
|
|
|
bool ignore);
|
2005-07-01 06:05:42 +02:00
|
|
|
int check_that_all_fields_are_given_values(THD *thd, TABLE *entry,
|
|
|
|
TABLE_LIST *table_list);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_prepare_delete(THD *thd, TABLE_LIST *table_list, Item **conds);
|
|
|
|
bool mysql_delete(THD *thd, TABLE_LIST *table, COND *conds, SQL_LIST *order,
|
2005-08-12 12:54:42 +02:00
|
|
|
ha_rows rows, ulonglong options);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_truncate(THD *thd, TABLE_LIST *table_list, bool dont_send_ok);
|
|
|
|
bool mysql_create_or_drop_trigger(THD *thd, TABLE_LIST *tables, bool create);
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE *open_ltable(THD *thd, TABLE_LIST *table_list, thr_lock_type update);
|
2004-07-16 00:15:55 +02:00
|
|
|
TABLE *open_table(THD *thd, TABLE_LIST *table_list, MEM_ROOT* mem,
|
2005-07-13 11:48:13 +02:00
|
|
|
bool *refresh, uint flags);
|
2000-09-20 00:17:19 +02:00
|
|
|
TABLE *reopen_name_locked_table(THD* thd, TABLE_LIST* table);
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE *find_locked_table(THD *thd, const char *db,const char *table_name);
|
2005-03-16 15:11:01 +01:00
|
|
|
bool reopen_table(TABLE *table,bool locked);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool reopen_tables(THD *thd,bool get_locks,bool in_refresh);
|
2000-08-29 11:31:01 +02:00
|
|
|
void close_old_data_files(THD *thd, TABLE *table, bool abort_locks,
|
|
|
|
bool send_refresh);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool close_data_tables(THD *thd,const char *db, const char *table_name);
|
|
|
|
bool wait_for_tables(THD *thd);
|
2000-08-29 11:31:01 +02:00
|
|
|
bool table_is_used(TABLE *table, bool wait_for_name_lock);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool drop_locked_tables(THD *thd,const char *db, const char *table_name);
|
|
|
|
void abort_locked_tables(THD *thd,const char *db, const char *table_name);
|
2003-12-08 06:13:14 +01:00
|
|
|
void execute_init_command(THD *thd, sys_var_str *init_command_var,
|
|
|
|
rw_lock_t *var_mutex);
|
2004-11-12 20:24:16 +01:00
|
|
|
extern Field *not_found_field;
|
|
|
|
extern Field *view_ref_found;
|
2004-11-02 17:23:15 +01:00
|
|
|
|
|
|
|
enum find_item_error_report_type {REPORT_ALL_ERRORS, REPORT_EXCEPT_NOT_FOUND,
|
|
|
|
IGNORE_ERRORS, REPORT_EXCEPT_NON_UNIQUE,
|
|
|
|
IGNORE_EXCEPT_NON_UNIQUE};
|
2004-08-26 23:08:59 +02:00
|
|
|
Field *
|
2005-08-12 16:57:19 +02:00
|
|
|
find_field_in_tables(THD *thd, Item_ident *item,
|
|
|
|
TABLE_LIST *first_table, TABLE_LIST *last_table,
|
|
|
|
Item **ref, find_item_error_report_type report_error,
|
|
|
|
bool check_privileges, bool register_tree_change);
|
2004-09-08 11:29:21 +02:00
|
|
|
Field *
|
2005-08-12 16:57:19 +02:00
|
|
|
find_field_in_table_ref(THD *thd, TABLE_LIST *table_list,
|
|
|
|
const char *name, const char *item_name,
|
|
|
|
const char *table_name, const char *db_name,
|
|
|
|
uint length, Item **ref,
|
|
|
|
bool check_grants_table, bool check_grants_view,
|
|
|
|
bool allow_rowid,
|
|
|
|
uint *cached_field_index_ptr,
|
|
|
|
bool register_tree_change, TABLE_LIST **actual_table);
|
2004-09-08 11:29:21 +02:00
|
|
|
Field *
|
2005-08-12 16:57:19 +02:00
|
|
|
find_field_in_table(THD *thd, TABLE *table, const char *name,
|
|
|
|
uint length, bool check_grants, bool allow_rowid,
|
|
|
|
uint *cached_field_index_ptr);
|
2001-12-10 10:02:26 +01:00
|
|
|
#ifdef HAVE_OPENSSL
|
2003-05-30 15:41:19 +02:00
|
|
|
#include <openssl/des.h>
|
2002-12-04 23:14:51 +01:00
|
|
|
struct st_des_keyblock
|
|
|
|
{
|
2003-10-07 14:42:26 +02:00
|
|
|
DES_cblock key1, key2, key3;
|
2001-12-10 10:02:26 +01:00
|
|
|
};
|
|
|
|
struct st_des_keyschedule
|
|
|
|
{
|
2003-09-12 20:33:43 +02:00
|
|
|
DES_key_schedule ks1, ks2, ks3;
|
2001-12-10 10:02:26 +01:00
|
|
|
};
|
2001-12-13 14:53:18 +01:00
|
|
|
extern char *des_key_file;
|
2001-12-13 02:36:36 +01:00
|
|
|
extern struct st_des_keyschedule des_keyschedule[10];
|
2001-12-13 01:31:19 +01:00
|
|
|
extern uint des_default_key;
|
2001-12-13 14:53:18 +01:00
|
|
|
extern pthread_mutex_t LOCK_des_key_file;
|
|
|
|
bool load_des_key_file(const char *file_name);
|
2001-12-10 10:02:26 +01:00
|
|
|
#endif /* HAVE_OPENSSL */
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2001-12-17 18:59:20 +01:00
|
|
|
/* sql_do.cc */
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_do(THD *thd, List<Item> &values);
|
2001-12-17 18:59:20 +01:00
|
|
|
|
2005-01-21 03:36:40 +01:00
|
|
|
/* sql_analyse.h */
|
|
|
|
bool append_escaped(String *to_str, String *from_str);
|
|
|
|
|
2002-06-13 00:47:05 +02:00
|
|
|
/* sql_show.cc */
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysqld_show_open_tables(THD *thd,const char *wild);
|
|
|
|
bool mysqld_show_logs(THD *thd);
|
2003-06-27 15:29:10 +02:00
|
|
|
void append_identifier(THD *thd, String *packet, const char *name,
|
|
|
|
uint length);
|
2004-10-01 10:51:59 +02:00
|
|
|
int get_quote_char_for_identifier(THD *thd, const char *name, uint length);
|
2000-07-31 21:29:14 +02:00
|
|
|
void mysqld_list_fields(THD *thd,TABLE_LIST *table, const char *wild);
|
2005-03-16 15:11:01 +01:00
|
|
|
int mysqld_dump_create_info(THD *thd, TABLE_LIST *table_list, int fd);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysqld_show_create(THD *thd, TABLE_LIST *table_list);
|
|
|
|
bool mysqld_show_create_db(THD *thd, char *dbname, HA_CREATE_INFO *create);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
void mysqld_list_processes(THD *thd,const char *user,bool verbose);
|
|
|
|
int mysqld_show_status(THD *thd);
|
|
|
|
int mysqld_show_variables(THD *thd,const char *wild);
|
2004-07-10 11:13:05 +02:00
|
|
|
int mysql_find_files(THD *thd,List<char> *files, const char *db,
|
|
|
|
const char *path, const char *wild, bool dir);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysqld_show_storage_engines(THD *thd);
|
|
|
|
bool mysqld_show_privileges(THD *thd);
|
|
|
|
bool mysqld_show_column_types(THD *thd);
|
|
|
|
bool mysqld_help (THD *thd, const char *text);
|
2004-09-13 15:48:01 +02:00
|
|
|
void calc_sum_of_all_status(STATUS_VAR *to);
|
2002-06-12 23:13:12 +02:00
|
|
|
|
2004-11-13 11:56:39 +01:00
|
|
|
/* information schema */
|
|
|
|
extern LEX_STRING information_schema_name;
|
|
|
|
LEX_STRING *make_lex_string(THD *thd, LEX_STRING *lex_str,
|
|
|
|
const char* str, uint length,
|
2005-03-16 15:11:01 +01:00
|
|
|
bool allocate_lex_string);
|
2004-11-13 11:56:39 +01:00
|
|
|
ST_SCHEMA_TABLE *find_schema_table(THD *thd, const char* table_name);
|
|
|
|
ST_SCHEMA_TABLE *get_schema_table(enum enum_schema_tables schema_table_idx);
|
|
|
|
int prepare_schema_table(THD *thd, LEX *lex, Table_ident *table_ident,
|
|
|
|
enum enum_schema_tables schema_table_idx);
|
|
|
|
int make_schema_select(THD *thd, SELECT_LEX *sel,
|
|
|
|
enum enum_schema_tables schema_table_idx);
|
|
|
|
int mysql_schema_table(THD *thd, LEX *lex, TABLE_LIST *table_list);
|
|
|
|
int fill_schema_user_privileges(THD *thd, TABLE_LIST *tables, COND *cond);
|
|
|
|
int fill_schema_schema_privileges(THD *thd, TABLE_LIST *tables, COND *cond);
|
|
|
|
int fill_schema_table_privileges(THD *thd, TABLE_LIST *tables, COND *cond);
|
|
|
|
int fill_schema_column_privileges(THD *thd, TABLE_LIST *tables, COND *cond);
|
2004-11-13 22:26:15 +01:00
|
|
|
bool get_schema_tables_result(JOIN *join);
|
2004-11-13 11:56:39 +01:00
|
|
|
|
2002-06-12 23:13:12 +02:00
|
|
|
/* sql_prepare.cc */
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_stmt_prepare(THD *thd, char *packet, uint packet_length,
|
2005-03-16 15:11:01 +01:00
|
|
|
LEX_STRING *name);
|
2004-03-15 18:20:47 +01:00
|
|
|
void mysql_stmt_execute(THD *thd, char *packet, uint packet_length);
|
2004-04-12 23:58:48 +02:00
|
|
|
void mysql_sql_stmt_execute(THD *thd, LEX_STRING *stmt_name);
|
2004-08-03 12:32:21 +02:00
|
|
|
void mysql_stmt_fetch(THD *thd, char *packet, uint packet_length);
|
2005-06-17 21:26:25 +02:00
|
|
|
void mysql_stmt_close(THD *thd, char *packet);
|
2003-07-08 11:27:21 +02:00
|
|
|
void mysql_stmt_reset(THD *thd, char *packet);
|
2002-10-02 12:33:08 +02:00
|
|
|
void mysql_stmt_get_longdata(THD *thd, char *pos, ulong packet_length);
|
2005-06-09 16:17:45 +02:00
|
|
|
void reinit_stmt_before_use(THD *thd, LEX *lex);
|
2005-03-03 15:38:59 +01:00
|
|
|
void init_stmt_after_parse(THD*, LEX*);
|
2002-06-12 23:13:12 +02:00
|
|
|
|
2001-04-07 00:18:33 +02:00
|
|
|
/* sql_handler.cc */
|
2005-03-16 15:11:01 +01:00
|
|
|
bool mysql_ha_open(THD *thd, TABLE_LIST *tables, bool reopen);
|
2004-11-12 14:36:31 +01:00
|
|
|
bool mysql_ha_close(THD *thd, TABLE_LIST *tables);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool mysql_ha_read(THD *, TABLE_LIST *,enum enum_ha_read_modes,char *,
|
|
|
|
List<Item> *,enum ha_rkey_function,Item *,ha_rows,ha_rows);
|
2004-10-06 16:20:39 +02:00
|
|
|
int mysql_ha_flush(THD *thd, TABLE_LIST *tables, uint mode_flags);
|
2004-09-24 18:39:25 +02:00
|
|
|
/* mysql_ha_flush mode_flags bits */
|
|
|
|
#define MYSQL_HA_CLOSE_FINAL 0x00
|
|
|
|
#define MYSQL_HA_REOPEN_ON_USAGE 0x01
|
|
|
|
#define MYSQL_HA_FLUSH_ALL 0x02
|
2001-04-07 00:18:33 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* sql_base.cc */
|
2004-10-22 21:51:04 +02:00
|
|
|
#define TMP_TABLE_KEY_EXTRA 8
|
2000-07-31 21:29:14 +02:00
|
|
|
void set_item_name(Item *item,char *pos,uint length);
|
2002-12-06 20:11:27 +01:00
|
|
|
bool add_field_to_list(THD *thd, char *field_name, enum enum_field_types type,
|
2000-07-31 21:29:14 +02:00
|
|
|
char *length, char *decimal,
|
2002-06-02 20:22:20 +02:00
|
|
|
uint type_modifier,
|
2004-04-02 08:12:53 +02:00
|
|
|
Item *default_value, Item *on_update_value,
|
2003-09-16 09:14:40 +02:00
|
|
|
LEX_STRING *comment,
|
2004-12-02 09:48:43 +01:00
|
|
|
char *change, List<String> *interval_list,
|
|
|
|
CHARSET_INFO *cs,
|
2003-03-27 10:09:09 +01:00
|
|
|
uint uint_geom_type);
|
2005-03-04 22:14:35 +01:00
|
|
|
create_field * new_create_field(THD *thd, char *field_name, enum_field_types type,
|
|
|
|
char *length, char *decimals,
|
|
|
|
uint type_modifier,
|
|
|
|
Item *default_value, Item *on_update_value,
|
|
|
|
LEX_STRING *comment, char *change,
|
|
|
|
List<String> *interval_list, CHARSET_INFO *cs,
|
|
|
|
uint uint_geom_type);
|
2000-07-31 21:29:14 +02:00
|
|
|
void store_position_for_column(const char *name);
|
2005-03-16 15:11:01 +01:00
|
|
|
bool add_to_list(THD *thd, SQL_LIST &list,Item *group,bool asc);
|
2005-08-12 16:57:19 +02:00
|
|
|
Name_resolution_context *make_join_on_context(THD *thd, TABLE_LIST *left_op,
|
|
|
|
TABLE_LIST *right_op);
|
2000-07-31 21:29:14 +02:00
|
|
|
void add_join_on(TABLE_LIST *b,Item *expr);
|
2005-08-12 16:57:19 +02:00
|
|
|
void add_join_natural(TABLE_LIST *a,TABLE_LIST *b,List<String> *using_fields);
|
2002-11-29 15:40:18 +01:00
|
|
|
bool add_proc_to_list(THD *thd, Item *item);
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE *unlink_open_table(THD *thd,TABLE *list,TABLE *find);
|
|
|
|
|
|
|
|
SQL_SELECT *make_select(TABLE *head, table_map const_tables,
|
2005-03-16 15:11:01 +01:00
|
|
|
table_map read_tables, COND *conds,
|
|
|
|
bool allow_null_cond, int *error);
|
2004-11-12 20:24:16 +01:00
|
|
|
extern Item **not_found_item;
|
2003-01-25 01:25:52 +01:00
|
|
|
Item ** find_item_in_list(Item *item, List<Item> &items, uint *counter,
|
2004-09-30 14:28:17 +02:00
|
|
|
find_item_error_report_type report_error,
|
|
|
|
bool *unaliased);
|
2003-11-18 12:47:27 +01:00
|
|
|
bool get_key_map_from_key_list(key_map *map, TABLE *table,
|
2003-10-11 13:06:55 +02:00
|
|
|
List<String> *index_list);
|
2005-07-01 06:05:42 +02:00
|
|
|
bool insert_fields(THD *thd, Name_resolution_context *context,
|
2001-05-20 15:08:09 +02:00
|
|
|
const char *db_name, const char *table_name,
|
2005-07-01 06:05:42 +02:00
|
|
|
List_iterator<Item> *it, bool any_privileges);
|
|
|
|
bool setup_tables(THD *thd, Name_resolution_context *context,
|
2005-08-12 16:57:19 +02:00
|
|
|
List<TABLE_LIST> *from_clause, TABLE_LIST *tables,
|
|
|
|
Item **conds, TABLE_LIST **leaves, bool select_insert);
|
2003-01-25 01:25:52 +01:00
|
|
|
int setup_wild(THD *thd, TABLE_LIST *tables, List<Item> &fields,
|
|
|
|
List<Item> *sum_func_list, uint wild_num);
|
2005-07-01 06:05:42 +02:00
|
|
|
bool setup_fields(THD *thd, Item** ref_pointer_array,
|
2004-10-20 03:04:37 +02:00
|
|
|
List<Item> &item, bool set_query_id,
|
|
|
|
List<Item> *sum_func_list, bool allow_sum_func);
|
2005-07-01 06:05:42 +02:00
|
|
|
inline bool setup_fields_with_no_wrap(THD *thd, Item **ref_pointer_array,
|
|
|
|
List<Item> &item, bool set_query_id,
|
|
|
|
List<Item> *sum_func_list,
|
|
|
|
bool allow_sum_func)
|
|
|
|
{
|
|
|
|
bool res;
|
|
|
|
thd->lex->select_lex.no_wrap_view_item= TRUE;
|
|
|
|
res= setup_fields(thd, ref_pointer_array, item, set_query_id, sum_func_list,
|
|
|
|
allow_sum_func);
|
|
|
|
thd->lex->select_lex.no_wrap_view_item= FALSE;
|
|
|
|
return res;
|
|
|
|
}
|
2004-09-14 18:28:29 +02:00
|
|
|
int setup_conds(THD *thd, TABLE_LIST *tables, TABLE_LIST *leaves,
|
|
|
|
COND **conds);
|
2002-10-30 12:18:52 +01:00
|
|
|
int setup_ftfuncs(SELECT_LEX* select);
|
|
|
|
int init_ftfuncs(THD *thd, SELECT_LEX* select, bool no_order);
|
2000-07-31 21:29:14 +02:00
|
|
|
void wait_for_refresh(THD *thd);
|
2005-08-08 15:46:06 +02:00
|
|
|
int open_tables(THD *thd, TABLE_LIST **tables, uint *counter, uint flags);
|
2004-02-01 14:30:32 +01:00
|
|
|
int simple_open_n_lock_tables(THD *thd,TABLE_LIST *tables);
|
2004-10-20 03:04:37 +02:00
|
|
|
bool open_and_lock_tables(THD *thd,TABLE_LIST *tables);
|
2005-08-08 15:46:06 +02:00
|
|
|
bool open_normal_and_derived_tables(THD *thd, TABLE_LIST *tables, uint flags);
|
2004-02-09 13:44:03 +01:00
|
|
|
int lock_tables(THD *thd, TABLE_LIST *tables, uint counter);
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE *open_temporary_table(THD *thd, const char *path, const char *db,
|
|
|
|
const char *table_name, bool link_in_list);
|
|
|
|
bool rm_temporary_table(enum db_type base, char *path);
|
|
|
|
void free_io_cache(TABLE *entry);
|
|
|
|
void intern_close_table(TABLE *entry);
|
2002-09-03 15:28:01 +02:00
|
|
|
bool close_thread_table(THD *thd, TABLE **table_ptr);
|
2000-07-31 21:29:14 +02:00
|
|
|
void close_temporary_tables(THD *thd);
|
2004-09-03 20:43:04 +02:00
|
|
|
TABLE_LIST *find_table_in_list(TABLE_LIST *table,
|
|
|
|
uint offset_to_list,
|
|
|
|
const char *db_name,
|
|
|
|
const char *table_name);
|
2004-09-10 01:22:44 +02:00
|
|
|
TABLE_LIST *unique_table(TABLE_LIST *table, TABLE_LIST *table_list);
|
2000-07-31 21:29:14 +02:00
|
|
|
TABLE **find_temporary_table(THD *thd, const char *db, const char *table_name);
|
|
|
|
bool close_temporary_table(THD *thd, const char *db, const char *table_name);
|
2005-03-16 15:11:01 +01:00
|
|
|
void close_temporary(TABLE *table, bool delete_table);
|
2000-11-26 07:29:01 +01:00
|
|
|
bool rename_temporary_table(THD* thd, TABLE *table, const char *new_db,
|
2000-07-31 21:29:14 +02:00
|
|
|
const char *table_name);
|
2005-02-09 00:14:14 +01:00
|
|
|
void remove_db_from_cache(const char *db);
|
2000-07-31 21:29:14 +02:00
|
|
|
void flush_tables();
|
2005-07-31 11:49:55 +02:00
|
|
|
bool is_equal(const LEX_STRING *a, const LEX_STRING *b);
|
2005-07-26 16:55:58 +02:00
|
|
|
|
|
|
|
/* bits for last argument to remove_table_from_cache() */
|
2005-07-20 21:19:01 +02:00
|
|
|
#define RTFC_NO_FLAG 0x0000
|
|
|
|
#define RTFC_OWNED_BY_THD_FLAG 0x0001
|
|
|
|
#define RTFC_WAIT_OTHER_THREAD_FLAG 0x0002
|
|
|
|
#define RTFC_CHECK_KILLED_FLAG 0x0004
|
2000-11-28 03:47:47 +01:00
|
|
|
bool remove_table_from_cache(THD *thd, const char *db, const char *table,
|
2005-07-19 00:29:19 +02:00
|
|
|
uint flags);
|
2005-07-26 16:55:58 +02:00
|
|
|
|
2000-08-21 23:18:32 +02:00
|
|
|
bool close_cached_tables(THD *thd, bool wait_for_refresh, TABLE_LIST *tables);
|
2000-07-31 21:29:14 +02:00
|
|
|
void copy_field_from_tmp_record(Field *field,int offset);
|
2004-11-12 13:34:00 +01:00
|
|
|
bool fill_record(THD *thd, Field **field, List<Item> &values,
|
|
|
|
bool ignore_errors);
|
2005-05-24 20:19:33 +02:00
|
|
|
bool fill_record_n_invoke_before_triggers(THD *thd, List<Item> &fields,
|
|
|
|
List<Item> &values,
|
|
|
|
bool ignore_errors,
|
|
|
|
Table_triggers_list *triggers,
|
|
|
|
enum trg_event_type event);
|
|
|
|
bool fill_record_n_invoke_before_triggers(THD *thd, Field **field,
|
|
|
|
List<Item> &values,
|
|
|
|
bool ignore_errors,
|
|
|
|
Table_triggers_list *triggers,
|
|
|
|
enum trg_event_type event);
|
2001-07-11 09:36:22 +02:00
|
|
|
OPEN_TABLE_LIST *list_open_tables(THD *thd, const char *wild);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-09-03 20:43:04 +02:00
|
|
|
inline TABLE_LIST *find_table_in_global_list(TABLE_LIST *table,
|
|
|
|
const char *db_name,
|
|
|
|
const char *table_name)
|
|
|
|
{
|
|
|
|
return find_table_in_list(table, offsetof(TABLE_LIST, next_global),
|
|
|
|
db_name, table_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline TABLE_LIST *find_table_in_local_list(TABLE_LIST *table,
|
|
|
|
const char *db_name,
|
|
|
|
const char *table_name)
|
|
|
|
{
|
|
|
|
return find_table_in_list(table, offsetof(TABLE_LIST, next_local),
|
|
|
|
db_name, table_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* sql_calc.cc */
|
|
|
|
bool eval_const_cond(COND *cond);
|
|
|
|
|
|
|
|
/* sql_load.cc */
|
2004-10-28 10:02:48 +02:00
|
|
|
bool mysql_load(THD *thd, sql_exchange *ex, TABLE_LIST *table_list,
|
2005-03-16 02:32:47 +01:00
|
|
|
List<Item> &fields_vars, List<Item> &set_fields,
|
|
|
|
List<Item> &set_values_list,
|
|
|
|
enum enum_duplicates handle_duplicates, bool ignore,
|
2005-03-16 10:13:35 +01:00
|
|
|
bool local_file);
|
2004-09-28 19:08:00 +02:00
|
|
|
int write_record(THD *thd, TABLE *table, COPY_INFO *info);
|
2000-11-28 00:14:49 +01:00
|
|
|
|
|
|
|
/* sql_manager.cc */
|
|
|
|
/* bits set in manager_status */
|
|
|
|
#define MANAGER_BERKELEY_LOG_CLEANUP (1L << 0)
|
2000-11-28 21:59:46 +01:00
|
|
|
extern ulong volatile manager_status;
|
2001-12-26 15:49:10 +01:00
|
|
|
extern bool volatile manager_thread_in_use, mqh_used;
|
2000-11-28 00:14:49 +01:00
|
|
|
extern pthread_t manager_thread;
|
2002-11-07 02:54:00 +01:00
|
|
|
extern "C" pthread_handler_decl(handle_manager, arg);
|
2000-11-28 00:14:49 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* sql_test.cc */
|
|
|
|
#ifndef DBUG_OFF
|
|
|
|
void print_where(COND *cond,const char *info);
|
|
|
|
void print_cached_tables(void);
|
2002-10-16 16:21:47 +02:00
|
|
|
void TEST_filesort(SORT_FIELD *sortorder,uint s_length);
|
2004-05-10 14:48:50 +02:00
|
|
|
void print_plan(JOIN* join, double read_time, double record_count,
|
|
|
|
uint idx, const char *info);
|
2000-07-31 21:29:14 +02:00
|
|
|
#endif
|
2005-02-17 13:07:28 +01:00
|
|
|
void mysql_print_status();
|
2000-07-31 21:29:14 +02:00
|
|
|
/* key.cc */
|
|
|
|
int find_ref_key(TABLE *form,Field *field, uint *offset);
|
2004-08-27 15:37:13 +02:00
|
|
|
void key_copy(byte *to_key, byte *from_record, KEY *key_info, uint key_length);
|
|
|
|
void key_restore(byte *to_record, byte *from_key, KEY *key_info,
|
|
|
|
uint key_length);
|
2004-05-16 13:48:32 +02:00
|
|
|
bool key_cmp_if_same(TABLE *form,const byte *key,uint index,uint key_length);
|
2000-07-31 21:29:14 +02:00
|
|
|
void key_unpack(String *to,TABLE *form,uint index);
|
|
|
|
bool check_if_key_used(TABLE *table, uint idx, List<Item> &fields);
|
2004-05-16 13:48:32 +02:00
|
|
|
int key_cmp(KEY_PART_INFO *key_part, const byte *key, uint key_length);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-05-16 13:48:32 +02:00
|
|
|
bool init_errmessage(void);
|
2000-07-31 21:29:14 +02:00
|
|
|
void sql_perror(const char *message);
|
2004-08-14 03:38:37 +02:00
|
|
|
|
2004-08-30 08:37:36 +02:00
|
|
|
void vprint_msg_to_log(enum loglevel level, const char *format, va_list args);
|
|
|
|
void sql_print_error(const char *format, ...);
|
|
|
|
void sql_print_warning(const char *format, ...);
|
|
|
|
void sql_print_information(const char *format, ...);
|
2004-08-14 03:38:37 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
2001-10-08 03:58:07 +02:00
|
|
|
bool fn_format_relative_to_data_home(my_string to, const char *name,
|
|
|
|
const char *dir, const char *extension);
|
2005-01-16 13:16:23 +01:00
|
|
|
File open_binlog(IO_CACHE *log, const char *log_file_name,
|
|
|
|
const char **errmsg);
|
|
|
|
handlerton *binlog_init();
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2003-09-13 10:35:29 +02:00
|
|
|
/* mysqld.cc */
|
|
|
|
extern void yyerror(const char*);
|
|
|
|
|
2004-03-16 11:01:05 +01:00
|
|
|
/* item_func.cc */
|
|
|
|
extern bool check_reserved_words(LEX_STRING *name);
|
|
|
|
|
2003-11-03 13:01:59 +01:00
|
|
|
/* strfunc.cc */
|
2004-10-26 10:17:37 +02:00
|
|
|
ulonglong find_set(TYPELIB *lib, const char *x, uint length, CHARSET_INFO *cs,
|
2003-11-03 13:01:59 +01:00
|
|
|
char **err_pos, uint *err_len, bool *set_warning);
|
|
|
|
uint find_type(TYPELIB *lib, const char *find, uint length, bool part_match);
|
2004-10-25 14:51:26 +02:00
|
|
|
uint find_type2(TYPELIB *lib, const char *find, uint length, CHARSET_INFO *cs);
|
2004-12-21 14:12:27 +01:00
|
|
|
void unhex_type2(TYPELIB *lib);
|
2003-11-03 13:01:59 +01:00
|
|
|
uint check_word(TYPELIB *lib, const char *val, const char *end,
|
|
|
|
const char **end_of_word);
|
|
|
|
|
2004-02-06 21:57:22 +01:00
|
|
|
bool is_keyword(const char *name, uint len);
|
|
|
|
|
2003-12-30 11:08:19 +01:00
|
|
|
|
2004-01-30 07:32:35 +01:00
|
|
|
#define MY_DB_OPT_FILE "db.opt"
|
|
|
|
bool load_db_opt(THD *thd, const char *path, HA_CREATE_INFO *create);
|
2004-07-09 09:55:16 +02:00
|
|
|
bool my_dbopt_init(void);
|
|
|
|
void my_dbopt_cleanup(void);
|
2004-07-08 12:03:01 +02:00
|
|
|
void my_dbopt_free(void);
|
2003-12-30 11:08:19 +01:00
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
/*
|
|
|
|
External variables
|
|
|
|
*/
|
|
|
|
|
|
|
|
extern time_t start_time;
|
2001-10-02 04:53:00 +02:00
|
|
|
extern char *mysql_data_home,server_version[SERVER_VERSION_LENGTH],
|
2004-02-16 18:53:00 +01:00
|
|
|
mysql_real_data_home[], *opt_mysql_tmpdir, mysql_charsets_dir[],
|
2004-04-07 20:58:33 +02:00
|
|
|
def_ft_boolean_syntax[sizeof(ft_boolean_syntax)];
|
2002-10-08 14:39:37 +02:00
|
|
|
#define mysql_tmpdir (my_tmpdir(&mysql_tmpdir_list))
|
|
|
|
extern MY_TMPDIR mysql_tmpdir_list;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern const char *command_name[];
|
2003-09-26 12:33:13 +02:00
|
|
|
extern const char *first_keyword, *my_localhost, *delayed_user, *binary_keyword;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern const char **errmesg; /* Error messages */
|
|
|
|
extern const char *myisam_recover_options_str;
|
2003-09-08 20:58:09 +02:00
|
|
|
extern const char *in_left_expr_name, *in_additional_cond;
|
2005-03-27 14:15:21 +02:00
|
|
|
extern const char * const triggers_file_ext;
|
2005-07-19 18:06:49 +02:00
|
|
|
extern const char * const trigname_file_ext;
|
2003-11-03 11:28:36 +01:00
|
|
|
extern Eq_creator eq_creator;
|
|
|
|
extern Ne_creator ne_creator;
|
|
|
|
extern Gt_creator gt_creator;
|
|
|
|
extern Lt_creator lt_creator;
|
|
|
|
extern Ge_creator ge_creator;
|
|
|
|
extern Le_creator le_creator;
|
2005-01-21 14:51:24 +01:00
|
|
|
extern char language[FN_REFLEN], reg_ext[FN_EXTLEN];
|
2002-07-23 17:31:22 +02:00
|
|
|
extern char glob_hostname[FN_REFLEN], mysql_home[FN_REFLEN];
|
2004-06-18 08:11:31 +02:00
|
|
|
extern char pidfile_name[FN_REFLEN], system_time_zone[30], *opt_init_file;
|
2005-03-12 20:09:54 +01:00
|
|
|
extern char log_error_file[FN_REFLEN], *opt_tc_log_file;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern double log_10[32];
|
2004-03-15 15:28:21 +01:00
|
|
|
extern ulonglong log_10_int[20];
|
2002-12-05 15:38:49 +01:00
|
|
|
extern ulonglong keybuff_size;
|
2005-08-12 12:54:42 +02:00
|
|
|
extern ulonglong thd_startup_options;
|
2005-01-16 13:16:23 +01:00
|
|
|
extern ulong refresh_version,flush_version, thread_id;
|
2004-04-01 22:47:20 +02:00
|
|
|
extern ulong binlog_cache_use, binlog_cache_disk_use;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern ulong aborted_threads,aborted_connects;
|
|
|
|
extern ulong delayed_insert_timeout;
|
|
|
|
extern ulong delayed_insert_limit, delayed_queue_size;
|
|
|
|
extern ulong delayed_insert_threads, delayed_insert_writes;
|
|
|
|
extern ulong delayed_rows_in_use,delayed_insert_errors;
|
2003-03-02 20:39:03 +01:00
|
|
|
extern ulong slave_open_temp_tables;
|
|
|
|
extern ulong query_cache_size, query_cache_min_res_unit;
|
2005-08-12 12:54:42 +02:00
|
|
|
extern ulong slow_launch_threads, slow_launch_time;
|
2004-09-13 15:48:01 +02:00
|
|
|
extern ulong table_cache_size;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern ulong max_connections,max_connect_errors, connect_timeout;
|
2005-03-02 11:29:48 +01:00
|
|
|
extern ulong slave_net_timeout, slave_trans_retries;
|
2005-01-19 22:54:01 +01:00
|
|
|
extern uint max_user_connections;
|
2004-09-13 15:48:01 +02:00
|
|
|
extern ulong what_to_log,flush_time;
|
2005-05-26 20:36:14 +02:00
|
|
|
extern ulong query_buff_size, thread_stack;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern ulong binlog_cache_size, max_binlog_cache_size, open_files_limit;
|
2003-07-06 17:59:54 +02:00
|
|
|
extern ulong max_binlog_size, max_relay_log_size;
|
|
|
|
extern ulong rpl_recovery_rank, thread_cache_size;
|
2004-09-13 15:48:01 +02:00
|
|
|
extern ulong back_log;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern ulong specialflag, current_pid;
|
2004-06-10 15:56:13 +02:00
|
|
|
extern ulong expire_logs_days, sync_binlog_period, sync_binlog_counter;
|
2005-06-07 10:30:09 +02:00
|
|
|
extern ulong opt_tc_log_size, tc_log_max_pages_used, tc_log_page_size;
|
|
|
|
extern ulong tc_log_page_waits;
|
2004-11-18 11:00:42 +01:00
|
|
|
extern my_bool relay_log_purge, opt_innodb_safe_binlog, opt_innodb;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern uint test_flags,select_errors,ha_open_options;
|
2003-06-14 10:37:42 +02:00
|
|
|
extern uint protocol_version, mysqld_port, dropping_tables;
|
2003-12-30 12:14:21 +01:00
|
|
|
extern uint delay_key_write_options, lower_case_table_names;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern bool opt_endinfo, using_udf_functions, locked_in_memory;
|
2004-10-20 00:28:42 +02:00
|
|
|
extern bool opt_using_transactions, mysqld_embedded;
|
2004-05-19 15:03:32 +02:00
|
|
|
extern bool using_update_log, opt_large_files, server_id_supplied;
|
2003-01-28 19:56:35 +01:00
|
|
|
extern bool opt_log, opt_update_log, opt_bin_log, opt_slow_log, opt_error_log;
|
2002-08-22 15:50:58 +02:00
|
|
|
extern bool opt_disable_networking, opt_skip_show_db;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern bool volatile abort_loop, shutdown_in_progress, grant_option;
|
2004-03-26 12:14:40 +01:00
|
|
|
extern bool mysql_proc_table_exists;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern uint volatile thread_count, thread_running, global_read_lock;
|
2002-08-22 15:50:58 +02:00
|
|
|
extern my_bool opt_sql_bin_update, opt_safe_user_create, opt_no_mix_types;
|
2003-12-30 12:14:21 +01:00
|
|
|
extern my_bool opt_safe_show_db, opt_local_infile;
|
2002-08-22 15:50:58 +02:00
|
|
|
extern my_bool opt_slave_compressed_protocol, use_temp_pool;
|
2004-03-06 09:43:35 +01:00
|
|
|
extern my_bool opt_readonly, lower_case_file_system;
|
2005-03-03 19:51:29 +01:00
|
|
|
extern my_bool opt_enable_named_pipe, opt_sync_frm, opt_allow_suspicious_udfs;
|
2003-07-08 00:36:14 +02:00
|
|
|
extern my_bool opt_secure_auth;
|
2005-06-16 23:58:36 +02:00
|
|
|
extern my_bool opt_log_slow_admin_statements;
|
2005-05-26 16:44:46 +02:00
|
|
|
extern my_bool sp_automatic_privileges, opt_noacl;
|
2005-05-05 14:20:53 +02:00
|
|
|
extern my_bool opt_old_style_user_limits, trust_routine_creators;
|
2004-06-20 19:11:02 +02:00
|
|
|
extern uint opt_crash_binlog_innodb;
|
2003-06-14 10:37:42 +02:00
|
|
|
extern char *shared_memory_base_name, *mysqld_unix_port;
|
2003-01-04 16:33:17 +01:00
|
|
|
extern bool opt_enable_shared_memory;
|
2004-06-18 08:11:31 +02:00
|
|
|
extern char *default_tz_name;
|
2004-12-14 20:26:31 +01:00
|
|
|
extern my_bool opt_large_pages;
|
|
|
|
extern uint opt_large_page_size;
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2004-07-12 06:43:38 +02:00
|
|
|
extern MYSQL_LOG mysql_log,mysql_slow_log,mysql_bin_log;
|
2000-11-28 03:47:47 +01:00
|
|
|
extern FILE *bootstrap_file;
|
2005-01-16 13:16:23 +01:00
|
|
|
extern int bootstrap_error;
|
2005-08-04 12:23:21 +02:00
|
|
|
extern FILE *stderror_file;
|
2004-11-08 00:13:54 +01:00
|
|
|
extern pthread_key(MEM_ROOT**,THR_MALLOC);
|
2000-07-31 21:29:14 +02:00
|
|
|
extern pthread_mutex_t LOCK_mysql_create_db,LOCK_Acl,LOCK_open,
|
|
|
|
LOCK_thread_count,LOCK_mapped_file,LOCK_user_locks, LOCK_status,
|
2004-02-27 20:30:08 +01:00
|
|
|
LOCK_error_log, LOCK_delayed_insert, LOCK_uuid_generator,
|
2000-07-31 21:29:14 +02:00
|
|
|
LOCK_delayed_status, LOCK_delayed_create, LOCK_crypt, LOCK_timezone,
|
2005-03-16 08:40:19 +01:00
|
|
|
LOCK_slave_list, LOCK_active_mi, LOCK_manager, LOCK_global_read_lock,
|
2005-07-19 20:05:49 +02:00
|
|
|
LOCK_global_system_variables, LOCK_user_conn,
|
2005-05-18 18:00:21 +02:00
|
|
|
LOCK_bytes_sent, LOCK_bytes_received;
|
2005-07-19 18:25:05 +02:00
|
|
|
#ifdef HAVE_OPENSSL
|
|
|
|
extern pthread_mutex_t LOCK_des_key_file;
|
|
|
|
#endif
|
2003-07-18 11:11:01 +02:00
|
|
|
extern rw_lock_t LOCK_grant, LOCK_sys_init_connect, LOCK_sys_init_slave;
|
2002-06-28 18:30:09 +02:00
|
|
|
extern pthread_cond_t COND_refresh, COND_thread_count, COND_manager;
|
2000-07-31 21:29:14 +02:00
|
|
|
extern pthread_attr_t connection_attrib;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern I_List<THD> threads;
|
2003-07-06 18:09:57 +02:00
|
|
|
extern I_List<NAMED_LIST> key_caches;
|
2001-02-07 22:27:19 +01:00
|
|
|
extern MY_BITMAP temp_pool;
|
2003-09-18 15:58:02 +02:00
|
|
|
extern String my_empty_string;
|
2003-12-20 00:16:10 +01:00
|
|
|
extern const String my_null_string;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern SHOW_VAR init_vars[],status_vars[], internal_vars[];
|
2002-06-28 18:30:09 +02:00
|
|
|
extern struct system_variables global_system_variables;
|
2002-07-23 17:31:22 +02:00
|
|
|
extern struct system_variables max_system_variables;
|
2004-09-13 15:48:01 +02:00
|
|
|
extern struct system_status_var global_status_var;
|
2002-12-05 02:40:33 +01:00
|
|
|
extern struct rand_struct sql_rand;
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2003-11-03 13:01:59 +01:00
|
|
|
extern const char *opt_date_time_formats[];
|
|
|
|
extern KNOWN_DATE_TIME_FORMAT known_date_time_formats[];
|
2003-10-20 10:24:18 +02:00
|
|
|
|
2003-09-29 21:06:31 +02:00
|
|
|
extern String null_string;
|
2003-09-13 10:35:29 +02:00
|
|
|
extern HASH open_cache;
|
|
|
|
extern TABLE *unused_tables;
|
|
|
|
extern I_List<i_string> binlog_do_db, binlog_ignore_db;
|
|
|
|
extern const char* any_db;
|
|
|
|
extern struct my_option my_long_options[];
|
2005-07-31 11:49:55 +02:00
|
|
|
extern const LEX_STRING view_type;
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2002-07-25 07:12:42 +02:00
|
|
|
/* optional things, have_* variables */
|
|
|
|
|
2004-05-21 03:13:11 +02:00
|
|
|
extern SHOW_COMP_OPTION have_isam, have_innodb, have_berkeley_db;
|
2004-08-13 05:57:18 +02:00
|
|
|
extern SHOW_COMP_OPTION have_example_db, have_archive_db, have_csv_db;
|
2004-12-11 21:03:51 +01:00
|
|
|
extern SHOW_COMP_OPTION have_federated_db;
|
2005-04-05 13:17:49 +02:00
|
|
|
extern SHOW_COMP_OPTION have_blackhole_db;
|
|
|
|
extern SHOW_COMP_OPTION have_ndbcluster;
|
2002-07-25 07:12:42 +02:00
|
|
|
extern SHOW_COMP_OPTION have_raid, have_openssl, have_symlink;
|
2005-04-05 13:17:49 +02:00
|
|
|
extern SHOW_COMP_OPTION have_query_cache;
|
2004-05-27 17:31:30 +02:00
|
|
|
extern SHOW_COMP_OPTION have_geometry, have_rtree_keys;
|
2003-01-28 07:38:28 +01:00
|
|
|
extern SHOW_COMP_OPTION have_crypt;
|
2003-04-10 02:50:30 +02:00
|
|
|
extern SHOW_COMP_OPTION have_compress;
|
2002-08-08 02:12:02 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
#ifndef __WIN__
|
|
|
|
extern pthread_t signal_thread;
|
|
|
|
#endif
|
|
|
|
|
2002-09-16 14:55:19 +02:00
|
|
|
#ifdef HAVE_OPENSSL
|
|
|
|
extern struct st_VioSSLAcceptorFd * ssl_acceptor_fd;
|
|
|
|
#endif /* HAVE_OPENSSL */
|
|
|
|
|
2005-05-31 11:08:14 +02:00
|
|
|
MYSQL_LOCK *mysql_lock_tables(THD *thd, TABLE **table, uint count, uint flags);
|
|
|
|
/* mysql_lock_tables() flags bits */
|
|
|
|
#define MYSQL_LOCK_IGNORE_GLOBAL_READ_LOCK 0x0001
|
|
|
|
#define MYSQL_LOCK_IGNORE_FLUSH 0x0002
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
void mysql_unlock_tables(THD *thd, MYSQL_LOCK *sql_lock);
|
|
|
|
void mysql_unlock_read_tables(THD *thd, MYSQL_LOCK *sql_lock);
|
|
|
|
void mysql_unlock_some_tables(THD *thd, TABLE **table,uint count);
|
|
|
|
void mysql_lock_remove(THD *thd, MYSQL_LOCK *locked,TABLE *table);
|
|
|
|
void mysql_lock_abort(THD *thd, TABLE *table);
|
2005-07-19 00:29:19 +02:00
|
|
|
bool mysql_lock_abort_for_thread(THD *thd, TABLE *table);
|
2000-07-31 21:29:14 +02:00
|
|
|
MYSQL_LOCK *mysql_lock_merge(MYSQL_LOCK *a,MYSQL_LOCK *b);
|
2001-08-14 19:33:49 +02:00
|
|
|
bool lock_global_read_lock(THD *thd);
|
|
|
|
void unlock_global_read_lock(THD *thd);
|
2004-09-09 05:59:26 +02:00
|
|
|
bool wait_if_global_read_lock(THD *thd, bool abort_on_refresh,
|
|
|
|
bool is_not_commit);
|
2001-08-14 19:33:49 +02:00
|
|
|
void start_waiting_global_read_lock(THD *thd);
|
2004-12-02 23:02:38 +01:00
|
|
|
bool make_global_read_lock_block_commit(THD *thd);
|
2005-04-27 22:58:11 +02:00
|
|
|
bool set_protect_against_global_read_lock(void);
|
|
|
|
void unset_protect_against_global_read_lock(void);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2000-08-21 02:07:54 +02:00
|
|
|
/* Lock based on name */
|
2001-09-02 12:47:00 +02:00
|
|
|
int lock_and_wait_for_table_name(THD *thd, TABLE_LIST *table_list);
|
2000-08-21 02:07:54 +02:00
|
|
|
int lock_table_name(THD *thd, TABLE_LIST *table_list);
|
|
|
|
void unlock_table_name(THD *thd, TABLE_LIST *table_list);
|
|
|
|
bool wait_for_locked_table_names(THD *thd, TABLE_LIST *table_list);
|
2003-03-03 19:42:49 +01:00
|
|
|
bool lock_table_names(THD *thd, TABLE_LIST *table_list);
|
|
|
|
void unlock_table_names(THD *thd, TABLE_LIST *table_list,
|
2005-03-16 15:11:01 +01:00
|
|
|
TABLE_LIST *last_table);
|
2000-08-21 02:07:54 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
/* old unireg functions */
|
|
|
|
|
|
|
|
void unireg_init(ulong options);
|
2002-11-20 21:56:57 +01:00
|
|
|
void unireg_end(void);
|
2004-04-08 16:56:45 +02:00
|
|
|
bool mysql_create_frm(THD *thd, my_string file_name,
|
2005-07-27 12:05:30 +02:00
|
|
|
const char *db, const char *table,
|
2004-04-08 16:56:45 +02:00
|
|
|
HA_CREATE_INFO *create_info,
|
|
|
|
List<create_field> &create_field,
|
|
|
|
uint key_count,KEY *key_info,handler *db_type);
|
2005-07-22 05:08:54 +02:00
|
|
|
int rea_create_table(THD *thd, my_string file_name,
|
2005-07-27 12:05:30 +02:00
|
|
|
const char *db, const char *table,
|
2005-07-22 05:08:54 +02:00
|
|
|
HA_CREATE_INFO *create_info,
|
2000-07-31 21:29:14 +02:00
|
|
|
List<create_field> &create_field,
|
|
|
|
uint key_count,KEY *key_info);
|
|
|
|
int format_number(uint inputflag,uint max_length,my_string pos,uint length,
|
|
|
|
my_string *errpos);
|
2004-09-17 02:08:23 +02:00
|
|
|
int openfrm(THD *thd, const char *name,const char *alias,uint filestat,
|
|
|
|
uint prgflag, uint ha_open_flags, TABLE *outparam);
|
2004-04-15 09:14:14 +02:00
|
|
|
int readfrm(const char *name, const void** data, uint* length);
|
|
|
|
int writefrm(const char* name, const void* data, uint len);
|
2000-07-31 21:29:14 +02:00
|
|
|
int closefrm(TABLE *table);
|
2005-06-17 23:14:44 +02:00
|
|
|
db_type get_table_type(THD *thd, const char *name);
|
2000-07-31 21:29:14 +02:00
|
|
|
int read_string(File file, gptr *to, uint length);
|
|
|
|
void free_blobs(TABLE *table);
|
|
|
|
int set_zone(int nr,int min_zone,int max_zone);
|
|
|
|
ulong convert_period_to_month(ulong period);
|
|
|
|
ulong convert_month_to_period(ulong month);
|
|
|
|
void get_date_from_daynr(long daynr,uint *year, uint *month,
|
|
|
|
uint *day);
|
2005-07-31 11:49:55 +02:00
|
|
|
my_time_t TIME_to_timestamp(THD *thd, const TIME *t, my_bool *not_exist);
|
2004-06-18 08:11:31 +02:00
|
|
|
bool str_to_time_with_warn(const char *str,uint length,TIME *l_time);
|
2004-06-24 17:08:36 +02:00
|
|
|
timestamp_type str_to_datetime_with_warn(const char *str, uint length,
|
|
|
|
TIME *l_time, uint flags);
|
2002-12-11 08:17:51 +01:00
|
|
|
void localtime_to_TIME(TIME *to, struct tm *from);
|
2003-06-23 09:56:44 +02:00
|
|
|
void calc_time_from_sec(TIME *to, long seconds, long microseconds);
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-03-15 15:28:21 +01:00
|
|
|
void make_truncated_value_warning(THD *thd, const char *str_val,
|
2004-09-28 19:08:00 +02:00
|
|
|
uint str_length, timestamp_type time_type,
|
|
|
|
const char *field_name);
|
2003-11-03 13:01:59 +01:00
|
|
|
extern DATE_TIME_FORMAT *date_time_format_make(timestamp_type format_type,
|
|
|
|
const char *format_str,
|
|
|
|
uint format_length);
|
|
|
|
extern DATE_TIME_FORMAT *date_time_format_copy(THD *thd,
|
|
|
|
DATE_TIME_FORMAT *format);
|
|
|
|
const char *get_date_time_format_str(KNOWN_DATE_TIME_FORMAT *format,
|
|
|
|
timestamp_type type);
|
|
|
|
extern bool make_date_time(DATE_TIME_FORMAT *format, TIME *l_time,
|
|
|
|
timestamp_type type, String *str);
|
2004-05-25 00:03:49 +02:00
|
|
|
void make_datetime(const DATE_TIME_FORMAT *format, const TIME *l_time,
|
|
|
|
String *str);
|
|
|
|
void make_date(const DATE_TIME_FORMAT *format, const TIME *l_time,
|
|
|
|
String *str);
|
|
|
|
void make_time(const DATE_TIME_FORMAT *format, const TIME *l_time,
|
|
|
|
String *str);
|
2003-10-20 10:24:18 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
int test_if_number(char *str,int *res,bool allow_wildcards);
|
|
|
|
void change_byte(byte *,uint,char,char);
|
|
|
|
void init_read_record(READ_RECORD *info, THD *thd, TABLE *reg_form,
|
|
|
|
SQL_SELECT *select,
|
2001-03-11 22:09:09 +01:00
|
|
|
int use_record_cache, bool print_errors);
|
2000-07-31 21:29:14 +02:00
|
|
|
void end_read_record(READ_RECORD *info);
|
2002-10-16 16:21:47 +02:00
|
|
|
ha_rows filesort(THD *thd, TABLE *form,struct st_sort_field *sortorder,
|
|
|
|
uint s_length, SQL_SELECT *select,
|
|
|
|
ha_rows max_rows, ha_rows *examined_rows);
|
2003-05-06 00:38:38 +02:00
|
|
|
void filesort_free_buffers(TABLE *table);
|
2000-07-31 21:29:14 +02:00
|
|
|
void change_double_for_sort(double nr,byte *to);
|
2005-05-19 22:04:08 +02:00
|
|
|
double my_double_round(double value, int dec, bool truncate);
|
2000-07-31 21:29:14 +02:00
|
|
|
int get_quick_record(SQL_SELECT *select);
|
|
|
|
int calc_weekday(long daynr,bool sunday_first_day_of_week);
|
2003-12-07 12:10:21 +01:00
|
|
|
uint calc_week(TIME *l_time, uint week_behaviour, uint *year);
|
2000-07-31 21:29:14 +02:00
|
|
|
void find_date(char *pos,uint *vek,uint flag);
|
|
|
|
TYPELIB *convert_strings_to_array_type(my_string *typelibs, my_string *end);
|
|
|
|
TYPELIB *typelib(List<String> &strings);
|
|
|
|
ulong get_form_pos(File file, uchar *head, TYPELIB *save_names);
|
|
|
|
ulong make_new_entry(File file,uchar *fileinfo,TYPELIB *formnames,
|
|
|
|
const char *newname);
|
|
|
|
ulong next_io_size(ulong pos);
|
2002-06-02 20:22:20 +02:00
|
|
|
void append_unescaped(String *res, const char *pos, uint length);
|
2005-07-28 16:09:54 +02:00
|
|
|
int create_frm(THD *thd, char *name, const char *db, const char *table,
|
2005-07-22 05:08:54 +02:00
|
|
|
uint reclength,uchar *fileinfo,
|
2000-07-31 21:29:14 +02:00
|
|
|
HA_CREATE_INFO *create_info, uint keys);
|
|
|
|
void update_create_info_from_table(HA_CREATE_INFO *info, TABLE *form);
|
|
|
|
int rename_file_ext(const char * from,const char * to,const char * ext);
|
2003-01-29 17:56:34 +01:00
|
|
|
bool check_db_name(char *db);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool check_column_name(const char *name);
|
|
|
|
bool check_table_name(const char *name, uint length);
|
2003-02-12 20:55:37 +01:00
|
|
|
char *get_field(MEM_ROOT *mem, Field *field);
|
2003-05-29 23:47:31 +02:00
|
|
|
bool get_field(MEM_ROOT *mem, Field *field, class String *res);
|
2002-03-12 18:37:58 +01:00
|
|
|
int wild_case_compare(CHARSET_INFO *cs, const char *str,const char *wildstr);
|
2000-11-21 07:38:08 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* from hostname.cc */
|
|
|
|
struct in_addr;
|
|
|
|
my_string ip_to_hostname(struct in_addr *in,uint *errors);
|
|
|
|
void inc_host_errors(struct in_addr *in);
|
|
|
|
void reset_host_errors(struct in_addr *in);
|
|
|
|
bool hostname_cache_init();
|
|
|
|
void hostname_cache_free();
|
|
|
|
void hostname_cache_refresh(void);
|
2004-04-28 16:45:08 +02:00
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
/* sql_cache.cc */
|
2000-07-31 21:29:14 +02:00
|
|
|
extern bool sql_cache_init();
|
|
|
|
extern void sql_cache_free();
|
|
|
|
extern int sql_cache_hit(THD *thd, char *inBuf, uint length);
|
|
|
|
|
2005-07-16 01:29:13 +02:00
|
|
|
/* item_func.cc */
|
2003-07-06 18:09:57 +02:00
|
|
|
Item *get_system_var(THD *thd, enum_var_type var_type, LEX_STRING name,
|
|
|
|
LEX_STRING component);
|
2004-06-01 15:27:40 +02:00
|
|
|
int get_var_with_binlog(THD *thd, LEX_STRING &name,
|
|
|
|
user_var_entry **out_entry);
|
2003-01-27 18:37:25 +01:00
|
|
|
/* log.cc */
|
|
|
|
bool flush_error_log(void);
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2003-06-10 20:42:29 +02:00
|
|
|
/* sql_list.cc */
|
|
|
|
void free_list(I_List <i_string_pair> *list);
|
|
|
|
void free_list(I_List <i_string> *list);
|
|
|
|
|
2003-09-13 10:35:29 +02:00
|
|
|
/* sql_yacc.cc */
|
|
|
|
extern int yyparse(void *thd);
|
|
|
|
|
|
|
|
/* frm_crypt.cc */
|
|
|
|
#ifdef HAVE_CRYPTED_FRM
|
|
|
|
SQL_CRYPT *get_crypt_for_frm(void);
|
|
|
|
#endif
|
|
|
|
|
2004-07-16 00:15:55 +02:00
|
|
|
#include "sql_view.h"
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
/* Some inline functions for more speed */
|
|
|
|
|
2002-12-06 20:11:27 +01:00
|
|
|
inline bool add_item_to_list(THD *thd, Item *item)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-05-05 20:54:37 +02:00
|
|
|
return thd->lex->current_select->add_item_to_list(thd, item);
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-06 20:11:27 +01:00
|
|
|
|
|
|
|
inline bool add_value_to_list(THD *thd, Item *value)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-05-05 20:54:37 +02:00
|
|
|
return thd->lex->value_list.push_back(value);
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-06 20:11:27 +01:00
|
|
|
|
|
|
|
inline bool add_order_to_list(THD *thd, Item *item, bool asc)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-05-05 20:54:37 +02:00
|
|
|
return thd->lex->current_select->add_order_to_list(thd, item, asc);
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-06 20:11:27 +01:00
|
|
|
|
|
|
|
inline bool add_group_to_list(THD *thd, Item *item, bool asc)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-05-05 20:54:37 +02:00
|
|
|
return thd->lex->current_select->add_group_to_list(thd, item, asc);
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-06 20:11:27 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
inline void mark_as_null_row(TABLE *table)
|
|
|
|
{
|
|
|
|
table->null_row=1;
|
2000-11-20 01:57:02 +01:00
|
|
|
table->status|=STATUS_NULL_ROW;
|
2005-01-06 12:00:13 +01:00
|
|
|
bfill(table->null_flags,table->s->null_bytes,255);
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-11-07 22:45:19 +01:00
|
|
|
|
2003-07-23 16:36:56 +02:00
|
|
|
inline void table_case_convert(char * name, uint length)
|
|
|
|
{
|
|
|
|
if (lower_case_table_names)
|
2005-06-06 13:54:15 +02:00
|
|
|
files_charset_info->cset->casedn(files_charset_info,
|
|
|
|
name, length, name, length);
|
2003-08-29 12:44:35 +02:00
|
|
|
}
|
|
|
|
|
2003-12-30 12:14:21 +01:00
|
|
|
inline const char *table_case_name(HA_CREATE_INFO *info, const char *name)
|
|
|
|
{
|
|
|
|
return ((lower_case_table_names == 2 && info->alias) ? info->alias : name);
|
|
|
|
}
|
2004-02-11 00:06:46 +01:00
|
|
|
|
2004-02-27 20:30:08 +01:00
|
|
|
inline ulong sql_rnd_with_mutex()
|
|
|
|
{
|
|
|
|
pthread_mutex_lock(&LOCK_thread_count);
|
|
|
|
ulong tmp=(ulong) (my_rnd(&sql_rand) * 0xffffffff); /* make all bits random */
|
|
|
|
pthread_mutex_unlock(&LOCK_thread_count);
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
2003-11-03 11:28:36 +01:00
|
|
|
Comp_creator *comp_eq_creator(bool invert);
|
|
|
|
Comp_creator *comp_ge_creator(bool invert);
|
|
|
|
Comp_creator *comp_gt_creator(bool invert);
|
|
|
|
Comp_creator *comp_le_creator(bool invert);
|
|
|
|
Comp_creator *comp_lt_creator(bool invert);
|
|
|
|
Comp_creator *comp_ne_creator(bool invert);
|
2002-11-07 22:45:19 +01:00
|
|
|
|
2003-10-08 16:40:54 +02:00
|
|
|
Item * all_any_subquery_creator(Item *left_expr,
|
|
|
|
chooser_compare_func_creator cmp,
|
|
|
|
bool all,
|
|
|
|
SELECT_LEX *select_lex);
|
|
|
|
|
2003-07-02 00:45:22 +02:00
|
|
|
/*
|
|
|
|
clean/setup table fields and map
|
|
|
|
|
|
|
|
SYNOPSYS
|
|
|
|
setup_table_map()
|
|
|
|
table - TABLE structure pointer (which should be setup)
|
|
|
|
table_list TABLE_LIST structure pointer (owner of TABLE)
|
|
|
|
tablenr - table number
|
|
|
|
*/
|
2003-08-29 12:44:35 +02:00
|
|
|
|
2003-07-02 00:45:22 +02:00
|
|
|
inline void setup_table_map(TABLE *table, TABLE_LIST *table_list, uint tablenr)
|
|
|
|
{
|
|
|
|
table->used_fields= 0;
|
|
|
|
table->const_table= 0;
|
2003-08-20 16:35:12 +02:00
|
|
|
table->null_row= 0;
|
2003-07-02 00:45:22 +02:00
|
|
|
table->status= STATUS_NO_RECORD;
|
2005-01-06 12:00:13 +01:00
|
|
|
table->keys_in_use_for_query= table->s->keys_in_use;
|
2005-02-05 16:16:29 +01:00
|
|
|
table->maybe_null= table_list->outer_join;
|
2005-08-06 01:43:35 +02:00
|
|
|
TABLE_LIST *embedding= table_list->embedding;
|
|
|
|
while (!table->maybe_null && embedding)
|
|
|
|
{
|
|
|
|
table->maybe_null= embedding->outer_join;
|
|
|
|
embedding= embedding->embedding;
|
|
|
|
}
|
2003-07-02 00:45:22 +02:00
|
|
|
table->tablenr= tablenr;
|
|
|
|
table->map= (table_map) 1 << tablenr;
|
|
|
|
table->force_index= table_list->force_index;
|
|
|
|
}
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
|
2004-01-23 13:02:57 +01:00
|
|
|
|
2004-12-06 17:45:32 +01:00
|
|
|
/*
|
|
|
|
SYNOPSYS
|
|
|
|
hexchar_to_int()
|
|
|
|
convert a hex digit into number
|
|
|
|
*/
|
|
|
|
|
|
|
|
inline int hexchar_to_int(char c)
|
|
|
|
{
|
|
|
|
if (c <= '9' && c >= '0')
|
|
|
|
return c-'0';
|
|
|
|
c|=32;
|
|
|
|
if (c <= 'f' && c >= 'a')
|
|
|
|
return c-'a'+10;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-03-29 16:57:07 +02:00
|
|
|
/*
|
|
|
|
Some functions that are different in the embedded library and the normal
|
|
|
|
server
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef EMBEDDED_LIBRARY
|
|
|
|
extern "C" void unireg_abort(int exit_code);
|
|
|
|
void kill_delayed_threads(void);
|
2005-05-31 12:06:15 +02:00
|
|
|
bool check_stack_overrun(THD *thd, long margin, char *dummy);
|
2004-03-29 16:57:07 +02:00
|
|
|
#else
|
|
|
|
#define unireg_abort(exit_code) DBUG_RETURN(exit_code)
|
|
|
|
inline void kill_delayed_threads(void) {}
|
2005-05-31 12:06:15 +02:00
|
|
|
#define check_stack_overrun(A, B, C) 0
|
2004-03-29 16:57:07 +02:00
|
|
|
#endif
|
2004-02-10 18:44:02 +01:00
|
|
|
|
This will be pushed only after I fix the testsuite.
This is the main commit for Worklog tasks:
* A more dynamic binlog format which allows small changes (1064)
* Log session variables in Query_log_event (1063)
Below 5.0 means 5.0.0.
MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
works for queries, except LOAD DATA INFILE (for this it would have to wait
for Dmitri's push of WL#874, which in turns waits for the present push, so...
the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
Apart from that, the new binlog format is designed so that it can tolerate
a little variation in the events (so that a 5.0.0 slave could replicate a
5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
later add replication of charsets it should break nothing. And when I later
add a UID to every event, it should break nothing.
The main change brought by this patch is a new type of event, Format_description_log_event,
which describes some lengthes in other event types. This event is needed for
the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
we can later add more bytes to the header of every event without breaking compatibility.
Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
can have a different number of status variables, stored as pairs (code, value); that's
how SQL_MODE and session variables and catalog are stored. Like this, we can later
add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
if we want.
MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
so both can be "hot" upgrades.
Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
3.23 and 4.x can't be slaves of 5.0.
So downgrading from 5.0 to 4.x may be complicated.
Log_event::log_pos is now the position of the end of the event, which is
more useful than the position of the beginning. We take care about compatibility
with <5.0 (in which log_pos is the beginning).
I added a short test for replication of SQL_MODE and some other variables.
TODO:
- after committing this, merge the latest 5.0 into it
- fix all tests
- update the manual with upgrade notes.
2003-12-18 01:09:05 +01:00
|
|
|
#endif /* MYSQL_CLIENT */
|