mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 12:32:27 +01:00
4653621909
New (simpler) internal timestamp handling. More debuging to heap tables. Small cleanups to multi-table-delete false -> 0 and true -> 1 (We should use TRUE and FALSE) heap/_check.c: Added checking of rows heap/hp_delete.c: Extra debugging heap/hp_scan.c: Extra debugging heap/hp_update.c: Extra debugging heap/hp_write.c: Extra debugging include/my_base.h: Added option to disable row cache when using updates isam/extra.c: Added option to disable row cache when using updates myisam/mi_check.c: Comment cleanup myisam/mi_extra.c: Added option to disable row cache when using updates myisam/sort.c: Indentaion cleanups myisammrg/myrg_extra.c: Added option to disable row cache when using updates mysql-test/r/multi_update.result: Updated results mysql-test/t/multi_update.test: Cleanup up to only use table names t1, t2,... mysys/mf_iocache.c: Safety fix sql/item_cmpfunc.cc: change true-> 1 and false -> 0 sql/mysql_priv.h: Cleaned up SQL_LIST handling sql/sql_base.cc: Fixed grant checking if SELECT tablename.* sql/sql_class.h: Cleaned up multi-table-update sql/sql_delete.cc: Fixed OPTION_SAFE_UPDATE checking in multi-table-delete. Fixed query-cache invalidation in multi-table-delete sql/sql_insert.cc: cleaned up timestamp handling sql/sql_olap.cc: false -> 0 sql/sql_parse.cc: Optimized some list handling. Moved multi-table-update to sql_update.cc sql/sql_select.cc: More comments Fixed create_tmp_table for multi-table-update sql/sql_select.h: New prototypes sql/sql_union.cc: false -> 0 Cleaned up timestamp handling sql/sql_update.cc: New multi-update-table code sql/sql_yacc.yy: false -> 0, true -> 1 Optimized some list handling sql/table.h: Added union for temporary values. Made shared int to be able to store counters. sql/uniques.cc: Indentation cleanup
176 lines
5.8 KiB
C++
176 lines
5.8 KiB
C++
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
|
/* Structs that defines the TABLE */
|
|
|
|
class Item; /* Needed by ORDER */
|
|
class GRANT_TABLE;
|
|
|
|
/* Order clause list element */
|
|
|
|
typedef struct st_order {
|
|
struct st_order *next;
|
|
Item **item; /* Point at item in select fields */
|
|
bool asc; /* true if ascending */
|
|
bool free_me; /* true if item isn't shared */
|
|
bool in_field_list; /* true if in select field list */
|
|
Field *field; /* If tmp-table group */
|
|
char *buff; /* If tmp-table group */
|
|
table_map used,depend_map;
|
|
} ORDER;
|
|
|
|
typedef struct st_grant_info
|
|
{
|
|
GRANT_TABLE *grant_table;
|
|
uint version;
|
|
ulong privilege;
|
|
ulong want_privilege;
|
|
} GRANT_INFO;
|
|
|
|
enum tmp_table_type {NO_TMP_TABLE=0, TMP_TABLE=1, TRANSACTIONAL_TMP_TABLE=2};
|
|
|
|
/* Table cache entry struct */
|
|
|
|
class Field_timestamp;
|
|
class Field_blob;
|
|
|
|
struct st_table {
|
|
handler *file;
|
|
Field **field; /* Pointer to fields */
|
|
Field_blob **blob_field; /* Pointer to blob fields */
|
|
HASH name_hash; /* hash of field names */
|
|
byte *record[3]; /* Pointer to records */
|
|
uint fields; /* field count */
|
|
uint reclength; /* Recordlength */
|
|
uint rec_buff_length;
|
|
uint keys,key_parts,primary_key,max_key_length,max_unique_length;
|
|
uint total_key_length;
|
|
uint uniques;
|
|
uint null_fields; /* number of null fields */
|
|
uint blob_fields; /* number of blob fields */
|
|
key_map keys_in_use, keys_for_keyread;
|
|
key_map quick_keys, used_keys, keys_in_use_for_query;
|
|
KEY *key_info; /* data of keys in database */
|
|
TYPELIB keynames; /* Pointers to keynames */
|
|
ha_rows max_rows; /* create information */
|
|
ha_rows min_rows; /* create information */
|
|
ulong avg_row_length; /* create information */
|
|
ulong raid_chunksize;
|
|
TYPELIB fieldnames; /* Pointer to fieldnames */
|
|
TYPELIB *intervals; /* pointer to interval info */
|
|
enum db_type db_type; /* table_type for handler */
|
|
enum row_type row_type; /* How rows are stored */
|
|
uint db_create_options; /* Create options from database */
|
|
uint db_options_in_use; /* Options in use */
|
|
uint db_record_offset; /* if HA_REC_IN_SEQ */
|
|
uint db_stat; /* mode of file as in handler.h */
|
|
uint raid_type,raid_chunks;
|
|
uint status; /* Used by postfix.. */
|
|
uint system; /* Set if system record */
|
|
ulong time_stamp; /* Set to offset+1 of record */
|
|
uint timestamp_field_offset;
|
|
uint next_number_index;
|
|
uint blob_ptr_size; /* 4 or 8 */
|
|
uint next_number_key_offset;
|
|
int current_lock; /* Type of lock on table */
|
|
enum tmp_table_type tmp_table;
|
|
my_bool copy_blobs; /* copy_blobs when storing */
|
|
my_bool null_row; /* All columns are null */
|
|
my_bool maybe_null,outer_join; /* Used with OUTER JOIN */
|
|
my_bool distinct,const_table,no_rows;
|
|
my_bool key_read, bulk_insert;
|
|
my_bool crypted;
|
|
my_bool db_low_byte_first; /* Portable row format */
|
|
my_bool locked_by_flush;
|
|
my_bool locked_by_name;
|
|
my_bool fulltext_searched;
|
|
my_bool crashed;
|
|
my_bool is_view;
|
|
my_bool no_keyread;
|
|
Field *next_number_field, /* Set if next_number is activated */
|
|
*found_next_number_field, /* Set on open */
|
|
*rowid_field;
|
|
Field_timestamp *timestamp_field;
|
|
my_string comment; /* Comment about table */
|
|
REGINFO reginfo; /* field connections */
|
|
MEM_ROOT mem_root;
|
|
GRANT_INFO grant;
|
|
|
|
char *table_cache_key;
|
|
char *table_name,*real_name,*path;
|
|
uint key_length; /* Length of key */
|
|
uint tablenr,used_fields,null_bytes;
|
|
table_map map; /* ID bit of table (1,2,4,8,16...) */
|
|
ulong version,flush_version;
|
|
uchar *null_flags;
|
|
IO_CACHE *io_cache; /* If sorted trough file*/
|
|
byte *record_pointers; /* If sorted in memory */
|
|
ha_rows found_records; /* How many records in sort */
|
|
ORDER *group;
|
|
ha_rows quick_rows[MAX_KEY];
|
|
uint quick_key_parts[MAX_KEY];
|
|
key_part_map const_key_parts[MAX_KEY];
|
|
ulong query_id;
|
|
|
|
union /* Temporary variables */
|
|
{
|
|
uint temp_pool_slot; /* Used by intern temp tables */
|
|
struct st_table_list *pos_in_table_list;
|
|
};
|
|
|
|
THD *in_use; /* Which thread uses this */
|
|
struct st_table *next,*prev;
|
|
};
|
|
|
|
|
|
#define JOIN_TYPE_LEFT 1
|
|
#define JOIN_TYPE_RIGHT 2
|
|
|
|
typedef struct st_table_list
|
|
{
|
|
struct st_table_list *next;
|
|
char *db, *alias, *real_name;
|
|
Item *on_expr; /* Used with outer join */
|
|
struct st_table_list *natural_join; /* natural join on this table*/
|
|
/* ... join ... USE INDEX ... IGNORE INDEX */
|
|
List<String> *use_index,*ignore_index;
|
|
TABLE *table;
|
|
GRANT_INFO grant;
|
|
thr_lock_type lock_type;
|
|
uint outer_join; /* Which join type */
|
|
uint shared; /* Used in union or in multi-upd */
|
|
uint32 db_length, real_name_length;
|
|
bool straight; /* optimize with prev table */
|
|
bool updating; /* for replicate-do/ignore table */
|
|
bool do_redirect; /* To get the struct in UNION's */
|
|
} TABLE_LIST;
|
|
|
|
|
|
typedef struct st_changed_table_list
|
|
{
|
|
struct st_changed_table_list *next;
|
|
char *key;
|
|
uint32 key_length;
|
|
} CHANGED_TABLE_LIST;
|
|
|
|
|
|
typedef struct st_open_table_list
|
|
{
|
|
struct st_open_table_list *next;
|
|
char *db,*table;
|
|
uint32 in_use,locked;
|
|
} OPEN_TABLE_LIST;
|