426
576
the Session of that thread); that thread is (and must remain, for now) the
427
577
only responsible for freeing this member.
585
/* This constructor is called for backup statements */
588
Statement(LEX *lex_arg, MEM_ROOT *mem_root_arg, ulong id_arg);
592
struct st_savepoint {
593
struct st_savepoint *prev;
596
Ha_trx_info *ha_list;
599
enum xa_states {XA_NOTR=0, XA_ACTIVE, XA_IDLE, XA_PREPARED};
600
extern const char *xa_state_names[];
602
typedef struct st_xid_state {
603
/* For now, this is only used to catch duplicated external xids */
604
XID xid; // transaction identifier
605
enum xa_states xa_state; // used by external XA only
609
extern pthread_mutex_t LOCK_xid_cache;
610
extern HASH xid_cache;
611
bool xid_cache_init(void);
612
void xid_cache_free(void);
613
XID_STATE *xid_cache_search(XID *xid);
614
bool xid_cache_insert(XID *xid, enum xa_states xa_state);
615
bool xid_cache_insert(XID_STATE *xid_state);
616
void xid_cache_delete(XID_STATE *xid_state);
619
@class Security_context
620
@brief A set of Session members describing the current authenticated user.
623
class Security_context {
625
Security_context() {} /* Remove gcc warning */
627
host - host of the client
628
user - user of the client, set to NULL until the user has been read from
630
priv_user - The user privilege we are using. May be "" for anonymous user.
639
inline char *priv_host_name()
641
return (ip ? ip : (char *)"%");
647
A registry for item tree transformations performed during
648
query optimization. We register only those changes which require
649
a rollback to re-execute a prepared statement or stored procedure
653
struct Item_change_record;
654
typedef I_List<Item_change_record> Item_change_list;
658
Class that holds information about tables which were opened and locked
659
by the thread. It is also used to save/restore this information in
660
push_open_tables_state()/pop_open_tables_state().
663
class Open_tables_state
667
List of regular tables in use by this thread. Contains temporary and
668
base tables that were opened with @see open_tables().
672
List of temporary tables used by this thread. Contains user-level
673
temporary tables, created with CREATE TEMPORARY TABLE, and
674
internal temporary tables, created, e.g., to resolve a SELECT,
675
or for an intermediate table used in ALTER.
676
XXX Why are internal temporary tables added to this list?
678
Table *temporary_tables;
680
List of tables that were opened with HANDLER OPEN and are
681
still in use by this thread.
683
Table *handler_tables;
684
Table *derived_tables;
686
During a MySQL session, one can lock tables in two modes: automatic
687
or manual. In automatic mode all necessary tables are locked just before
688
statement execution, and all acquired locks are stored in 'lock'
689
member. Unlocking takes place automatically as well, when the
691
Manual mode comes into play when a user issues a 'LOCK TABLES'
692
statement. In this mode the user can only use the locked tables.
693
Trying to use any other tables will give an error. The locked tables are
694
stored in 'locked_tables' member. Manual locking is described in
695
the 'LOCK_TABLES' chapter of the MySQL manual.
696
See also lock_tables() for details.
700
Tables that were locked with explicit or implicit LOCK TABLES.
701
(Implicit LOCK TABLES happens when we are prelocking tables for
702
execution of statement which uses stored routines. See description
703
Session::prelocked_mode for more info.)
705
DRIZZLE_LOCK *locked_tables;
708
CREATE-SELECT keeps an extra lock for the table being
709
created. This field is used to keep the extra lock available for
710
lower level routines, which would otherwise miss that lock.
712
DRIZZLE_LOCK *extra_lock;
715
uint32_t current_tablenr;
718
BACKUPS_AVAIL = (1U << 0) /* There are backups available */
722
Flags with information about the open tables state.
724
uint32_t state_flags;
727
This constructor serves for creation of Open_tables_state instances
728
which are used as backup storage.
730
Open_tables_state() : state_flags(0U) { }
732
Open_tables_state(ulong version_arg);
734
void set_open_tables_state(Open_tables_state *state)
739
void reset_open_tables_state()
741
open_tables= temporary_tables= handler_tables= derived_tables= 0;
742
extra_lock= lock= locked_tables= 0;
748
/* Flags for the Session::system_thread variable */
749
enum enum_thread_type
752
SYSTEM_THREAD_SLAVE_IO,
753
SYSTEM_THREAD_SLAVE_SQL
758
This class represents the interface for internal error handlers.
759
Internal error handlers are exception handlers used by the server
762
class Internal_error_handler
765
Internal_error_handler() {}
766
virtual ~Internal_error_handler() {}
770
Handle an error condition.
771
This method can be implemented by a subclass to achieve any of the
773
- mask an error internally, prevent exposing it to the user,
774
- mask an error and throw another one instead.
775
When this method returns true, the error condition is considered
776
'handled', and will not be propagated to upper layers.
777
It is the responsability of the code installing an internal handler
778
to then check for trapped conditions, and implement logic to recover
779
from the anticipated conditions trapped during runtime.
781
This mechanism is similar to C++ try/throw/catch:
782
- 'try' correspond to <code>Session::push_internal_handler()</code>,
783
- 'throw' correspond to <code>my_error()</code>,
784
which invokes <code>my_message_sql()</code>,
785
- 'catch' correspond to checking how/if an internal handler was invoked,
786
before removing it from the exception stack with
787
<code>Session::pop_internal_handler()</code>.
789
@param sql_errno the error number
790
@param level the error level
791
@param session the calling thread
792
@return true if the error is handled
794
virtual bool handle_error(uint32_t sql_errno,
796
DRIZZLE_ERROR::enum_warning_level level,
797
Session *session) = 0;
802
Stores status of the currently executed statement.
803
Cleared at the beginning of the statement, and then
804
can hold either OK, ERROR, or EOF status.
805
Can not be assigned twice per statement.
808
class Diagnostics_area
811
enum enum_diagnostics_status
813
/** The area is cleared at start of a statement. */
815
/** Set whenever one calls my_ok(). */
817
/** Set whenever one calls my_eof(). */
819
/** Set whenever one calls my_error() or my_message(). */
821
/** Set in case of a custom response, such as one from COM_STMT_PREPARE. */
824
/** True if status information is sent to the client. */
826
/** Set to make set_error_status after set_{ok,eof}_status possible. */
827
bool can_overwrite_status;
829
void set_ok_status(Session *session, ha_rows affected_rows_arg,
830
uint64_t last_insert_id_arg,
831
const char *message);
832
void set_eof_status(Session *session);
833
void set_error_status(Session *session, uint32_t sql_errno_arg, const char *message_arg);
835
void disable_status();
837
void reset_diagnostics_area();
839
bool is_set() const { return m_status != DA_EMPTY; }
840
bool is_error() const { return m_status == DA_ERROR; }
841
bool is_eof() const { return m_status == DA_EOF; }
842
bool is_ok() const { return m_status == DA_OK; }
843
bool is_disabled() const { return m_status == DA_DISABLED; }
844
enum_diagnostics_status status() const { return m_status; }
846
const char *message() const
847
{ assert(m_status == DA_ERROR || m_status == DA_OK); return m_message; }
849
uint32_t sql_errno() const
850
{ assert(m_status == DA_ERROR); return m_sql_errno; }
852
uint32_t server_status() const
854
assert(m_status == DA_OK || m_status == DA_EOF);
855
return m_server_status;
858
ha_rows affected_rows() const
859
{ assert(m_status == DA_OK); return m_affected_rows; }
861
uint64_t last_insert_id() const
862
{ assert(m_status == DA_OK); return m_last_insert_id; }
864
uint32_t total_warn_count() const
866
assert(m_status == DA_OK || m_status == DA_EOF);
867
return m_total_warn_count;
870
Diagnostics_area() { reset_diagnostics_area(); }
873
/** Message buffer. Can be used by OK or ERROR status. */
874
char m_message[DRIZZLE_ERRMSG_SIZE];
876
SQL error number. One of ER_ codes from share/errmsg.txt.
877
Set by set_error_status.
879
uint32_t m_sql_errno;
882
Copied from session->server_status when the diagnostics area is assigned.
883
We need this member as some places in the code use the following pattern:
884
session->server_status|= ...
886
session->server_status&= ~...
887
Assigned by OK, EOF or ERROR.
889
uint32_t m_server_status;
891
The number of rows affected by the last statement. This is
892
semantically close to session->row_count_func, but has a different
893
life cycle. session->row_count_func stores the value returned by
894
function ROW_COUNT() and is cleared only by statements that
895
update its value, such as INSERT, UPDATE, DELETE and few others.
896
This member is cleared at the beginning of the next statement.
898
We could possibly merge the two, but life cycle of session->row_count_func
901
ha_rows m_affected_rows;
903
Similarly to the previous member, this is a replacement of
904
session->first_successful_insert_id_in_prev_stmt, which is used
905
to implement LAST_INSERT_ID().
907
uint64_t m_last_insert_id;
908
/** The total number of warnings. */
909
uint m_total_warn_count;
910
enum_diagnostics_status m_status;
912
@todo: the following Session members belong here:
913
- warn_list, warn_count,
919
Storage engine specific thread local data.
925
Storage engine specific thread local data.
926
Lifetime: one user connection.
930
0: Life time: one statement within a transaction. If @@autocommit is
931
on, also represents the entire transaction.
932
@sa trans_register_ha()
934
1: Life time: one transaction within a connection.
935
If the storage engine does not participate in a transaction,
936
this should not be used.
937
@sa trans_register_ha()
939
Ha_trx_info ha_info[2];
941
Ha_data() :ha_ptr(NULL) {}
947
For each client connection we create a separate thread with Session serving as
948
a thread/connection descriptor
951
class Session :public Statement,
952
public Open_tables_state
955
/* Used to execute base64 coded binlog events in MySQL server */
956
Relay_log_info* rli_fake;
432
959
Constant for Session::where initialization in the beginning of every query.
434
961
It's needed because we do not save/restore Session::where normally during
437
964
static const char * const DEFAULT_WHERE;
439
memory::Root warn_root; /**< Allocation area for warnings and errors */
440
plugin::Client *client; /**< Pointer to client object */
441
plugin::Scheduler *scheduler; /**< Pointer to scheduler object */
442
void *scheduler_arg; /**< Pointer to the optional scheduler argument */
443
HASH user_vars; /**< Hash of user variables defined during the session's lifetime */
444
struct system_variables variables; /**< Mutable local variables local to the session */
445
struct system_status_var status_var; /**< Session-local status counters */
446
struct system_status_var *initial_status_var; /* used by show status */
447
THR_LOCK_INFO lock_info; /**< Locking information for this session */
448
THR_LOCK_OWNER main_lock_id; /**< To use for conventional queries */
449
THR_LOCK_OWNER *lock_id; /**< If not main_lock_id, points to the lock_id of a cursor. */
450
pthread_mutex_t LOCK_delete; /**< Locked before session is deleted */
453
* A peek into the query string for the session. This is a best effort
454
* delivery, there is no guarantee whether the content is meaningful.
456
char process_list_info[PROCESS_LIST_WIDTH+1];
459
* A pointer to the stack frame of the scheduler thread
460
* which is called first in the thread for handling a client
465
SecurityContext security_ctx;
467
inline void checkSentry() const
469
assert(this->dbug_sentry == Session_SENTRY_MAGIC);
472
const SecurityContext& getSecurityContext() const
477
SecurityContext& getSecurityContext()
483
* Is this session viewable by the current user?
485
bool isViewable() const
487
return plugin::Authorization::isAuthorized(current_session->getSecurityContext(),
966
NET net; // client connection descriptor
967
MEM_ROOT warn_root; // For warnings and errors
968
Protocol *protocol; // Current protocol
969
Protocol_text protocol_text; // Normal protocol
970
HASH user_vars; // hash for user variables
971
String packet; // dynamic buffer for network I/O
972
String convert_buffer; // buffer for charset conversions
973
struct rand_struct rand; // used for authentication
974
struct system_variables variables; // Changeable local variables
975
struct system_status_var status_var; // Per thread statistic vars
976
struct system_status_var *initial_status_var; /* used by show status */
977
THR_LOCK_INFO lock_info; // Locking info of this thread
978
THR_LOCK_OWNER main_lock_id; // To use for conventional queries
979
THR_LOCK_OWNER *lock_id; // If not main_lock_id, points to
980
// the lock_id of a cursor.
981
pthread_mutex_t LOCK_delete; // Locked before session is deleted
983
A pointer to the stack frame of handle_one_connection(),
984
which is called first in the thread for handling a client
989
Currently selected catalog.
995
Some members of Session (currently 'Statement::db',
996
'catalog' and 'query') are set and alloced by the slave SQL thread
997
(for the Session of that thread); that thread is (and must remain, for now)
998
the only responsible for freeing these 3 members. If you add members
999
here, and you add code to set them in replication, don't forget to
1000
free_them_and_set_them_to_0 in replication properly. For details see
1001
the 'err:' label of the handle_slave_sql() in sql/slave.cc.
1003
@see handle_slave_sql
1006
Security_context main_security_ctx;
1007
Security_context *security_ctx;
1010
Points to info-string that we show in SHOW PROCESSLIST
1011
You are supposed to call Session_SET_PROC_INFO only if you have coded
1012
a time-consuming piece that MySQL can get stuck in for a long time.
1014
Set it using the session_proc_info(Session *thread, const char *message)
1017
void set_proc_info(const char *info) { proc_info= info; }
1018
const char* get_proc_info() const { return proc_info; }
493
1021
Used in error messages to tell user in what part of MySQL we found an
494
1022
error. E. g. when where= "having clause", if fix_fields() fails, user
495
1023
will know that the error was in having clause.
497
1025
const char *where;
1027
double tmp_double_value; /* Used in set_var.cc */
1028
ulong client_capabilities; /* What the client supports */
1029
ulong max_client_packet_length;
1031
HASH handler_tables_hash;
500
1033
One thread can hold up to one named user-level lock. This variable
501
1034
points to a lock object if the lock is present. See item_func.cc and
502
chapter 'Miscellaneous functions', for functions GET_LOCK, RELEASE_LOCK.
504
uint32_t dbug_sentry; /**< watch for memory corruption */
505
internal::st_my_thread_var *mysys_var;
507
* Type of current query: COM_STMT_PREPARE, COM_QUERY, etc. Set from
508
* first byte of the packet in executeStatement()
1035
chapter 'Miscellaneous functions', for functions GET_LOCK, RELEASE_LOCK.
1037
uint32_t dbug_sentry; // watch out for memory corruption
1038
struct st_my_thread_var *mysys_var;
1040
Type of current query: COM_STMT_PREPARE, COM_QUERY, etc. Set from
1041
first byte of the packet in do_command()
510
1043
enum enum_server_command command;
511
uint32_t file_id; /**< File ID for LOAD DATA INFILE */
512
/* @note the following three members should likely move to Client */
513
uint32_t max_client_packet_length; /**< Maximum number of bytes a client can send in a single packet */
516
uint64_t thr_create_utime; /**< track down slow pthread_create */
517
uint64_t start_utime;
518
uint64_t utime_after_lock;
1045
uint32_t file_id; // for LOAD DATA INFILE
1046
/* remote (peer) port */
1048
time_t start_time, user_time;
1049
uint64_t connect_utime, thr_create_utime; // track down slow pthread_create
1050
uint64_t start_utime, utime_after_lock;
520
1052
thr_lock_type update_lock_default;
523
Both of the following container points in session will be converted to an API.
527
1054
/* container for handler's private per-connection data */
528
std::vector<Ha_data> ha_data;
530
Id of current query. Statement can be reused to execute several queries
531
query_id is global in context of the whole MySQL server.
532
ID is automatically generated from an atomic counter.
533
It's used in Cursor code for various purposes: to check which columns
534
from table are necessary for this select, to check if it's necessary to
535
update auto-updatable fields (like auto_increment and timestamp).
538
query_id_t warn_query_id;
540
void **getEngineData(const plugin::MonitoredInTransaction *monitored);
541
ResourceContext *getResourceContext(const plugin::MonitoredInTransaction *monitored,
1055
Ha_data ha_data[MAX_HA];
1057
/* Place to store various things */
1058
void *session_marker;
1059
int binlog_setup_trx_data();
1062
Public interface to write RBR events to the binlog
1064
void binlog_start_trans_and_stmt();
1065
void binlog_set_stmt_begin();
1066
int binlog_write_table_map(Table *table, bool is_transactional);
1067
int binlog_write_row(Table* table, bool is_transactional,
1068
const unsigned char *new_data);
1069
int binlog_delete_row(Table* table, bool is_transactional,
1070
const unsigned char *old_data);
1071
int binlog_update_row(Table* table, bool is_transactional,
1072
const unsigned char *old_data, const unsigned char *new_data);
1074
void set_server_id(uint32_t sid) { server_id = sid; }
1077
Member functions to handle pending event for row-level logging.
1079
template <class RowsEventT> Rows_log_event*
1080
binlog_prepare_pending_rows_event(Table* table, uint32_t serv_id,
1082
bool is_transactional,
1084
Rows_log_event* binlog_get_pending_rows_event() const;
1085
void binlog_set_pending_rows_event(Rows_log_event* ev);
1086
int binlog_flush_pending_rows_event(bool stmt_end);
1089
uint32_t binlog_table_maps; // Number of table maps currently in the binlog
1091
enum enum_binlog_flag {
1092
BINLOG_FLAG_UNSAFE_STMT_PRINTED,
1097
Flags with per-thread information regarding the status of the
1100
uint32_t binlog_flags;
1102
uint32_t get_binlog_table_maps() const {
1103
return binlog_table_maps;
1105
void clear_binlog_table_maps() {
1106
binlog_table_maps= 0;
544
1111
struct st_transactions {
545
std::deque<NamedSavepoint> savepoints;
546
TransactionContext all; ///< Trans since BEGIN WORK
547
TransactionContext stmt; ///< Trans for current statement
1112
SAVEPOINT *savepoints;
1113
Session_TRANS all; // Trans since BEGIN WORK
1114
Session_TRANS stmt; // Trans for current statement
1115
bool on; // see ha_enable_transaction()
548
1116
XID_STATE xid_state;
1117
Rows_log_event *m_pending_rows_event;
1120
Tables changed in transaction (that must be invalidated in query cache).
1121
List contain only transactional tables, that not invalidated in query
1122
cache (instead of full list of changed in transaction tables).
1124
CHANGED_TableList* changed_tables;
1125
MEM_ROOT mem_root; // Transaction-life memory allocation pool
1130
free_root(&mem_root,MYF(MY_KEEP_PREALLOC));
1134
memset(this, 0, sizeof(*this));
1135
xid_state.xid.null();
1136
init_sql_alloc(&mem_root, ALLOC_ROOT_MIN_BLOCK_SIZE, 0);
563
1140
sigset_t signals;
1142
This is to track items changed during execution of a prepared
1143
statement/stored procedure. It's created by
1144
register_item_tree_change() in memory root of Session, and freed in
1145
rollback_item_tree_changes(). For conventional execution it's always
1148
Item_change_list change_list;
565
1150
/* Tells if LAST_INSERT_ID(#) was called for the current statement */
566
1151
bool arg_of_last_insert_id_function;
611
1216
in the binlog is still needed; the list's minimum will contain 3.
613
1218
Discrete_intervals_list auto_inc_intervals_in_cur_stmt_for_binlog;
614
/** Used by replication and SET INSERT_ID */
1219
/* Used by replication and SET INSERT_ID */
615
1220
Discrete_intervals_list auto_inc_intervals_forced;
617
uint64_t limit_found_rows;
618
uint64_t options; /**< Bitmap of options */
619
int64_t row_count_func; /**< For the ROW_COUNT() function */
620
ha_rows cuted_fields; /**< Count of "cut" or truncated fields. @todo Kill this friggin thing. */
623
* Number of rows we actually sent to the client, including "synthetic"
624
* rows in ROLLUP etc.
626
ha_rows sent_row_count;
629
* Number of rows we read, sent or not, including in create_sort_index()
631
ha_rows examined_row_count;
634
* The set of those tables whose fields are referenced in all subqueries
639
* Possibly this it is incorrect to have used tables in Session because
640
* with more than one subquery, it is not clear what does the field mean.
642
table_map used_tables;
647
This, and some other variables like 'count_cuted_fields'
648
maybe should be statement/cursor local, that is, moved to Statement
649
class. With current implementation warnings produced in each prepared
650
statement/cursor settle here.
652
List<DRIZZLE_ERROR> warn_list;
653
uint32_t warn_count[(uint32_t) DRIZZLE_ERROR::WARN_LEVEL_END];
654
uint32_t total_warn_count;
655
Diagnostics_area main_da;
659
/* Statement id is thread-wide. This counter is used to generate ids */
660
uint32_t statement_id_counter;
661
uint32_t rand_saved_seed1;
662
uint32_t rand_saved_seed2;
664
Row counter, mainly for errors and warnings. Not increased in
665
create_sort_index(); may differ from examined_row_count.
668
pthread_t real_id; /**< For debugging */
671
uint32_t global_read_lock;
672
uint32_t server_status;
673
uint32_t open_options;
674
uint32_t select_number; /**< number of select (used for EXPLAIN) */
675
/* variables.transaction_isolation is reset to this after each commit */
676
enum_tx_isolation session_tx_isolation;
677
enum_check_fields count_cuted_fields;
685
KILLED_NO_VALUE /* means none of the above states apply */
687
killed_state volatile killed;
689
bool some_tables_deleted;
693
Set to true if execution of the current compound statement
694
can not continue. In particular, disables activation of
695
CONTINUE or EXIT handlers of stored routines.
696
Reset in the end of processing of the current user request, in
697
@see mysql_reset_session_for_next_command().
701
Set by a storage engine to request the entire
702
transaction (that possibly spans multiple engines) to
703
rollback. Reset in ha_rollback.
705
bool transaction_rollback_request;
707
true if we are in a sub-statement and the current error can
708
not be safely recovered until we left the sub-statement mode.
709
In particular, disables activation of CONTINUE and EXIT
710
handlers inside sub-statements. E.g. if it is a deadlock
711
error and requires a transaction-wide rollback, this flag is
712
raised (traditionally, MySQL first has to close all the reads
713
via @see handler::ha_index_or_rnd_end() and only then perform
715
Reset to false when we leave the sub-statement mode.
717
bool is_fatal_sub_stmt_error;
718
/** for IS NULL => = last_insert_id() fix in remove_eq_conds() */
719
bool substitute_null_with_insert_id;
722
bool abort_on_warning;
723
bool got_warning; /**< Set on call to push_warning() */
724
bool no_warnings_for_error; /**< no warnings on call to my_error() */
725
/** set during loop of derived table processing */
726
bool derived_tables_processing;
727
bool tablespace_op; /**< This is true in DISCARD/IMPORT TABLESPACE */
729
/** Used by the sys_var class to store temporary values */
733
uint32_t uint32_t_value;
734
int32_t int32_t_value;
735
uint64_t uint64_t_value;
739
Character input stream consumed by the lexical analyser,
741
Note that since the parser is not re-entrant, we keep only one input
742
stream here. This member is valid only when executing code during parsing,
743
and may point to invalid memory after that.
745
Lex_input_stream *m_lip;
747
/** Place to store various things */
748
void *session_marker;
750
/** Keeps a copy of the previous table around in case we are just slamming on particular table */
754
Points to info-string that we show in SHOW PROCESSLIST
755
You are supposed to call Session_SET_PROC_INFO only if you have coded
756
a time-consuming piece that MySQL can get stuck in for a long time.
758
Set it using the session_proc_info(Session *thread, const char *message)
761
inline void set_proc_info(const char *info)
765
inline const char* get_proc_info() const
770
/** Sets this Session's current query ID */
771
inline void setQueryId(query_id_t in_query_id)
773
query_id= in_query_id;
776
/** Returns the current query ID */
777
inline query_id_t getQueryId() const
783
/** Sets this Session's warning query ID */
784
inline void setWarningQueryId(query_id_t in_query_id)
786
warn_query_id= in_query_id;
789
/** Returns the Session's warning query ID */
790
inline query_id_t getWarningQueryId() const
792
return warn_query_id;
795
/** Returns the current query text */
796
inline const std::string &getQueryString() const
801
/** Returns the length of the current query text */
802
inline size_t getQueryLength() const
805
return query.length();
810
/** Accessor method returning the session's ID. */
811
inline uint64_t getSessionId() const
816
/** Accessor method returning the server's ID. */
817
inline uint32_t getServerId() const
819
/* We return the global server ID. */
823
/** Returns the current transaction ID for the session's current statement */
824
inline my_xid getTransactionId()
826
return transaction.xid_state.xid.quick_get_my_xid();
829
1222
There is BUG#19630 where statement-based replication of stored
830
1223
functions/triggers with two auto_increment columns breaks.
831
1224
We however ensure that it works when there is 0 or 1 auto_increment
881
1281
auto_inc_intervals_forced.append(next_id, UINT64_MAX, 0);
884
Session(plugin::Client *client_arg);
1284
uint64_t limit_found_rows;
1285
uint64_t options; /* Bitmap of states */
1286
int64_t row_count_func; /* For the ROW_COUNT() function */
1287
ha_rows cuted_fields;
1290
number of rows we actually sent to the client, including "synthetic"
1293
ha_rows sent_row_count;
1296
number of rows we read, sent or not, including in create_sort_index()
1298
ha_rows examined_row_count;
1301
The set of those tables whose fields are referenced in all subqueries
1303
TODO: possibly this it is incorrect to have used tables in Session because
1304
with more than one subquery, it is not clear what does the field mean.
1306
table_map used_tables;
1307
USER_CONN *user_connect;
1308
const CHARSET_INFO *db_charset;
1310
FIXME: this, and some other variables like 'count_cuted_fields'
1311
maybe should be statement/cursor local, that is, moved to Statement
1312
class. With current implementation warnings produced in each prepared
1313
statement/cursor settle here.
1315
List <DRIZZLE_ERROR> warn_list;
1316
uint warn_count[(uint) DRIZZLE_ERROR::WARN_LEVEL_END];
1317
uint total_warn_count;
1318
Diagnostics_area main_da;
1321
Id of current query. Statement can be reused to execute several queries
1322
query_id is global in context of the whole MySQL server.
1323
ID is automatically generated from mutex-protected counter.
1324
It's used in handler code for various purposes: to check which columns
1325
from table are necessary for this select, to check if it's necessary to
1326
update auto-updatable fields (like auto_increment and timestamp).
1328
query_id_t query_id, warn_id;
1331
#ifdef ERROR_INJECT_SUPPORT
1332
ulong error_inject_value;
1334
/* Statement id is thread-wide. This counter is used to generate ids */
1335
ulong statement_id_counter;
1336
ulong rand_saved_seed1, rand_saved_seed2;
1338
Row counter, mainly for errors and warnings. Not increased in
1339
create_sort_index(); may differ from examined_row_count.
1342
pthread_t real_id; /* For debugging */
1343
my_thread_id thread_id;
1344
uint tmp_table, global_read_lock;
1345
uint server_status,open_options;
1346
enum enum_thread_type system_thread;
1347
uint32_t select_number; //number of select (used for EXPLAIN)
1348
/* variables.transaction_isolation is reset to this after each commit */
1349
enum_tx_isolation session_tx_isolation;
1350
enum_check_fields count_cuted_fields;
1352
DYNAMIC_ARRAY user_var_events; /* For user variables replication */
1353
MEM_ROOT *user_var_events_alloc; /* Allocate above array elements here */
1361
KILLED_NO_VALUE /* means neither of the states */
1363
killed_state volatile killed;
1365
/* scramble - random string sent to client on handshake */
1366
char scramble[SCRAMBLE_LENGTH+1];
1368
bool slave_thread, one_shot_set;
1369
/* tells if current statement should binlog row-based(1) or stmt-based(0) */
1370
bool current_stmt_binlog_row_based;
1371
bool some_tables_deleted;
1372
bool last_cuted_field;
1373
bool no_errors, password;
1375
Set to true if execution of the current compound statement
1376
can not continue. In particular, disables activation of
1377
CONTINUE or EXIT handlers of stored routines.
1378
Reset in the end of processing of the current user request, in
1379
@see mysql_reset_session_for_next_command().
1381
bool is_fatal_error;
1383
Set by a storage engine to request the entire
1384
transaction (that possibly spans multiple engines) to
1385
rollback. Reset in ha_rollback.
1387
bool transaction_rollback_request;
1389
true if we are in a sub-statement and the current error can
1390
not be safely recovered until we left the sub-statement mode.
1391
In particular, disables activation of CONTINUE and EXIT
1392
handlers inside sub-statements. E.g. if it is a deadlock
1393
error and requires a transaction-wide rollback, this flag is
1394
raised (traditionally, MySQL first has to close all the reads
1395
via @see handler::ha_index_or_rnd_end() and only then perform
1397
Reset to false when we leave the sub-statement mode.
1399
bool is_fatal_sub_stmt_error;
1400
bool query_start_used, rand_used, time_zone_used;
1401
/* for IS NULL => = last_insert_id() fix in remove_eq_conds() */
1402
bool substitute_null_with_insert_id;
1403
bool in_lock_tables;
1405
True if a slave error. Causes the slave to stop. Not the same
1406
as the statement execution error (is_error()), since
1407
a statement may be expected to return an error, e.g. because
1408
it returned an error on master, and this is OK on the slave.
1410
bool is_slave_error;
1413
/** is set if some thread specific value(s) used in a statement. */
1414
bool thread_specific_used;
1415
bool charset_is_system_charset, charset_is_collation_connection;
1416
bool charset_is_character_set_filesystem;
1417
bool abort_on_warning;
1418
bool got_warning; /* Set on call to push_warning() */
1419
bool no_warnings_for_error; /* no warnings on call to my_error() */
1420
/* set during loop of derived table processing */
1421
bool derived_tables_processing;
1422
bool tablespace_op; /* This is true in DISCARD/IMPORT TABLESPACE */
1425
If we do a purge of binary logs, log index info of the threads
1426
that are currently reading it needs to be adjusted. To do that
1427
each thread that is using LOG_INFO needs to adjust the pointer to it
1429
LOG_INFO* current_linfo;
1430
NET* slave_net; // network connection from slave -> m.
1431
/* Used by the sys_var class to store temporary values */
1437
uint64_t uint64_t_value;
1442
If true, mysql_bin_log::write(Log_event) call will not write events to
1443
binlog, and maintain 2 below variables instead (use
1444
mysql_bin_log.start_union_events to turn this on)
1448
If true, at least one mysql_bin_log::write(Log_event) call has been
1449
made after last mysql_bin_log.start_union_events() call.
1451
bool unioned_events;
1453
If true, at least one mysql_bin_log::write(Log_event e), where
1454
e.cache_stmt == true call has been made after last
1455
mysql_bin_log.start_union_events() call.
1457
bool unioned_events_trans;
1460
'queries' (actually SP statements) that run under inside this binlog
1461
union have session->query_id >= first_query_id.
1463
query_id_t first_query_id;
1467
Character input stream consumed by the lexical analyser,
1468
used during parsing.
1469
Note that since the parser is not re-entrant, we keep only one input
1470
stream here. This member is valid only when executing code during parsing,
1471
and may point to invalid memory after that.
1473
Lex_input_stream *m_lip;
1480
Initialize memory roots necessary for query processing and (!)
1481
pre-allocate memory for it. We can't do that in Session constructor because
1482
there are use cases (acl_init, watcher threads,
1483
killing mysqld) where it's vital to not allocate excessive and not used
1484
memory. Note, that we still don't return error from init_for_queries():
1485
if preallocation fails, we should notice that at the first call to
1488
void init_for_queries();
1489
void change_user(void);
887
1490
void cleanup(void);
889
* Cleans up after query.
893
* This function is used to reset thread data to its default state.
895
* This function is not suitable for setting thread data to some
896
* non-default values, as there is only one replication thread, so
897
* different master threads may overwrite data of each other on
900
1491
void cleanup_after_query();
1492
bool store_globals();
902
1493
void awake(Session::killed_state state_to_set);
904
* Pulls thread-specific variables into Session state.
906
* Returns true most times, or false if there was a problem
907
* allocating resources for thread-specific storage.
909
* @TODO Kill this. It's not necessary once my_thr_init() is bye bye.
915
Initialize memory roots necessary for query processing and (!)
916
pre-allocate memory for it. We can't do that in Session constructor because
917
there are use cases where it's vital to not allocate excessive and not used
920
void prepareForQueries();
923
* Executes a single statement received from the
926
* Returns true if the statement was successful, or false
931
* For profiling to work, it must never be called recursively.
933
* In MySQL, this used to be the do_command() C function whic
934
* accepted a single parameter of the THD pointer.
936
bool executeStatement();
939
* Reads a query from packet and stores it.
941
* Returns true if query is read and allocated successfully,
942
* false otherwise. On a return of false, Session::fatal_error
945
* @note Used in COM_QUERY and COM_STMT_PREPARE.
947
* Sets the following Session variables:
951
* @param The packet pointer to read from
952
* @param The length of the query to read
954
bool readAndStoreQuery(const char *in_packet, uint32_t in_packet_length);
957
* Ends the current transaction and (maybe) begins the next.
959
* Returns true if the transaction completed successfully,
962
* @param Completion type
964
bool endTransaction(enum enum_mysql_completiontype completion);
965
bool endActiveTransaction();
966
bool startTransaction(start_transaction_option_t opt= START_TRANS_NO_OPTIONS);
969
* Authenticates users, with error reporting.
971
* Returns true on success, or false on failure.
978
* This will initialize the session and begin the command loop.
983
* Schedule a session to be run on the default scheduler.
1495
enum enum_binlog_query_type {
1497
The query can be logged row-based or statement-based
1502
The query has to be logged statement-based
1507
The query represents a change to a table in the "mysql"
1508
database and is currently mapped to ROW_QUERY_TYPE.
1514
int binlog_query(enum_binlog_query_type qtype,
1515
char const *query, ulong query_len,
1516
bool is_trans, bool suppress_use,
1517
Session::killed_state killed_err_arg= Session::KILLED_NO_VALUE);
988
1520
For enter_cond() / exit_cond() to work the mutex must be got before
989
1521
enter_cond(); this mutex is then released by exit_cond().
990
1522
Usage must be: lock mutex; enter_cond(); your code; exit_cond().
992
const char* enter_cond(pthread_cond_t *cond, pthread_mutex_t* mutex, const char* msg);
993
void exit_cond(const char* old_msg);
995
inline time_t query_start() { return start_time; }
1524
inline const char* enter_cond(pthread_cond_t *cond, pthread_mutex_t* mutex,
1527
const char* old_msg = get_proc_info();
1528
safe_mutex_assert_owner(mutex);
1529
mysys_var->current_mutex = mutex;
1530
mysys_var->current_cond = cond;
1531
this->set_proc_info(msg);
1534
inline void exit_cond(const char* old_msg)
1537
Putting the mutex unlock in exit_cond() ensures that
1538
mysys_var->current_mutex is always unlocked _before_ mysys_var->mutex is
1539
locked (if that would not be the case, you'll get a deadlock if someone
1540
does a Session::awake() on you).
1542
pthread_mutex_unlock(mysys_var->current_mutex);
1543
pthread_mutex_lock(&mysys_var->mutex);
1544
mysys_var->current_mutex = 0;
1545
mysys_var->current_cond = 0;
1546
this->set_proc_info(old_msg);
1547
pthread_mutex_unlock(&mysys_var->mutex);
1549
inline time_t query_start() { query_start_used=1; return start_time; }
996
1550
inline void set_time()
1000
1554
start_time= user_time;
1001
connect_microseconds= start_utime= utime_after_lock= my_micro_time();
1555
start_utime= utime_after_lock= my_micro_time();
1004
1558
start_utime= utime_after_lock= my_micro_time_and_time(&start_time);
1006
inline void set_current_time() { start_time= time(NULL); }
1560
inline void set_current_time() { start_time= my_time(MY_WME); }
1007
1561
inline void set_time(time_t t)
1009
1563
start_time= user_time= t;
1010
1564
start_utime= utime_after_lock= my_micro_time();
1012
1566
void set_time_after_lock() { utime_after_lock= my_micro_time(); }
1014
* Returns the current micro-timestamp
1016
inline uint64_t getCurrentTimestamp()
1018
return my_micro_time();
1567
uint64_t current_utime() { return my_micro_time(); }
1020
1568
inline uint64_t found_rows(void)
1022
1570
return limit_found_rows;
1024
/** Returns whether the session is currently inside a transaction */
1025
inline bool inTransaction()
1572
inline bool active_transaction()
1027
1574
return server_status & SERVER_STATUS_IN_TRANS;
1273
1797
- for prepared queries, only to allocate runtime data. The parsed
1274
1798
tree itself is reused between executions and thus is stored elsewhere.
1276
memory::Root main_mem_root;
1279
* Marks all tables in the list which were used by current substatement
1280
* as free for reuse.
1282
* @param Head of the list of tables
1286
* The reason we reset query_id is that it's not enough to just test
1287
* if table->query_id != session->query_id to know if a table is in use.
1291
* SELECT f1_that_uses_t1() FROM t1;
1293
* In f1_that_uses_t1() we will see one instance of t1 where query_id is
1294
* set to query_id of original query.
1296
void mark_used_tables_as_free_for_reuse(Table *table);
1298
Mark all temporary tables which were used by the current statement or
1299
substatement as free for reuse, but only if the query_id can be cleared.
1301
@param session thread context
1303
@remark For temp tables associated with a open SQL HANDLER the query_id
1304
is not reset until the HANDLER is closed.
1306
void mark_temp_tables_as_free_for_reuse();
1310
/** A short cut for session->main_da.set_ok_status(). */
1311
inline void my_ok(ha_rows affected_rows= 0, ha_rows found_rows_arg= 0,
1312
uint64_t passed_id= 0, const char *message= NULL)
1314
main_da.set_ok_status(this, affected_rows, found_rows_arg, passed_id, message);
1318
/** A short cut for session->main_da.set_eof_status(). */
1320
inline void my_eof()
1322
main_da.set_eof_status(this);
1325
/* Some inline functions for more speed */
1327
inline bool add_item_to_list(Item *item)
1329
return lex->current_select->add_item_to_list(this, item);
1332
inline bool add_value_to_list(Item *value)
1334
return lex->value_list.push_back(value);
1337
inline bool add_order_to_list(Item *item, bool asc)
1339
return lex->current_select->add_order_to_list(this, item, asc);
1342
inline bool add_group_to_list(Item *item, bool asc)
1344
return lex->current_select->add_group_to_list(this, item, asc);
1346
void refresh_status();
1347
user_var_entry *getVariable(LEX_STRING &name, bool create_if_not_exists);
1350
* Closes all tables used by the current substatement, or all tables
1351
* used by this thread if we are on the upper level.
1353
void close_thread_tables();
1354
void close_old_data_files(bool morph_locks= false,
1355
bool send_refresh= false);
1356
void close_open_tables();
1357
void close_data_files_and_morph_locks(TableIdentifier &identifier);
1358
void close_data_files_and_morph_locks(const char *db, const char *table_name);
1361
bool free_cached_table();
1365
* Prepares statement for reopening of tables and recalculation of set of
1368
* @param Pointer to a pointer to a list of tables which we were trying to open and lock
1370
void close_tables_for_reopen(TableList **tables);
1374
* Open all tables in list, locks them (all, including derived)
1376
* @param Pointer to a list of tables for open & locking
1385
* The lock will automaticaly be freed by close_thread_tables()
1387
bool openTablesLock(TableList *tables);
1390
* Open all tables in list and process derived tables
1392
* @param Pointer to a list of tables for open
1393
* @param Bitmap of flags to modify how the tables will be open:
1394
* DRIZZLE_LOCK_IGNORE_FLUSH - open table even if someone has
1395
* done a flush or namelock on it.
1404
* This is to be used on prepare stage when you don't read any
1405
* data from the tables.
1407
bool openTables(TableList *tables, uint32_t flags= 0);
1409
int open_tables_from_list(TableList **start, uint32_t *counter, uint32_t flags= 0);
1411
Table *openTableLock(TableList *table_list, thr_lock_type lock_type);
1412
Table *openTable(TableList *table_list, bool *refresh, uint32_t flags= 0);
1414
void unlink_open_table(Table *find);
1415
void drop_open_table(Table *table, TableIdentifier &identifier);
1416
void close_cached_table(Table *table);
1418
/* Create a lock in the cache */
1419
Table *table_cache_insert_placeholder(const char *key, uint32_t key_length);
1420
bool lock_table_name_if_not_cached(TableIdentifier &identifier, Table **table);
1421
bool lock_table_name_if_not_cached(const char *db,
1422
const char *table_name, Table **table);
1424
typedef drizzled::hash_map<std::string, message::Table> TableMessageCache;
1425
TableMessageCache table_message_cache;
1427
bool storeTableMessage(TableIdentifier &identifier, message::Table &table_message);
1428
bool removeTableMessage(TableIdentifier &identifier);
1429
bool getTableMessage(TableIdentifier &identifier, message::Table &table_message);
1430
bool doesTableMessageExist(TableIdentifier &identifier);
1431
bool renameTableMessage(TableIdentifier &from, TableIdentifier &to);
1433
/* Work with temporary tables */
1434
Table *find_temporary_table(TableList *table_list);
1435
Table *find_temporary_table(const char *db, const char *table_name);
1436
Table *find_temporary_table(TableIdentifier &identifier);
1438
void doGetTableNames(CachedDirectory &directory,
1439
SchemaIdentifier &schema_identifier,
1440
std::set<std::string>& set_of_names);
1441
void doGetTableNames(SchemaIdentifier &schema_identifier,
1442
std::set<std::string>& set_of_names);
1444
void doGetTableIdentifiers(CachedDirectory &directory,
1445
SchemaIdentifier &schema_identifier,
1446
TableIdentifiers &set_of_identifiers);
1447
void doGetTableIdentifiers(SchemaIdentifier &schema_identifier,
1448
TableIdentifiers &set_of_identifiers);
1450
int doGetTableDefinition(drizzled::TableIdentifier &identifier,
1451
message::Table &table_proto);
1452
bool doDoesTableExist(TableIdentifier &identifier);
1454
void close_temporary_tables();
1455
void close_temporary_table(Table *table);
1456
// The method below just handles the de-allocation of the table. In
1457
// a better memory type world, this would not be needed.
1459
void nukeTable(Table *table);
1462
void dumpTemporaryTableNames(const char *id);
1463
int drop_temporary_table(TableList *table_list);
1464
bool rm_temporary_table(plugin::StorageEngine *base, TableIdentifier &identifier);
1465
bool rm_temporary_table(TableIdentifier &identifier);
1466
Table *open_temporary_table(TableIdentifier &identifier,
1467
bool link_in_list= true);
1469
/* Reopen operations */
1470
bool reopen_tables(bool get_locks, bool mark_share_as_old);
1471
bool reopen_name_locked_table(TableList* table_list, bool link_in);
1472
bool close_cached_tables(TableList *tables, bool wait_for_refresh, bool wait_for_placeholders);
1474
void wait_for_condition(pthread_mutex_t *mutex, pthread_cond_t *cond);
1475
int setup_conds(TableList *leaves, COND **conds);
1476
int lock_tables(TableList *tables, uint32_t count, bool *need_reopen);
1480
Return the default storage engine
1482
@param getDefaultStorageEngine()
1485
pointer to plugin::StorageEngine
1487
plugin::StorageEngine *getDefaultStorageEngine()
1489
if (variables.storage_engine)
1490
return variables.storage_engine;
1491
return global_system_variables.storage_engine;
1494
static void unlink(Session *session);
1800
MEM_ROOT main_mem_root;
1804
/** A short cut for session->main_da.set_ok_status(). */
1807
my_ok(Session *session, ha_rows affected_rows= 0, uint64_t id= 0,
1808
const char *message= NULL)
1810
session->main_da.set_ok_status(session, affected_rows, id, message);
1814
/** A short cut for session->main_da.set_eof_status(). */
1817
my_eof(Session *session)
1819
session->main_da.set_eof_status(session);
1822
#define tmp_disable_binlog(A) \
1823
{uint64_t tmp_disable_binlog__save_options= (A)->options; \
1824
(A)->options&= ~OPTION_BIN_LOG
1826
#define reenable_binlog(A) (A)->options= tmp_disable_binlog__save_options;}
1830
Used to hold information about file and file structure in exchange
1831
via non-DB file (...INTO OUTFILE..., ...LOAD DATA...)
1832
XXX: We never call destructor for objects of this class.
1835
class sql_exchange :public Sql_alloc
1838
enum enum_filetype filetype; /* load XML, Added by Arnold & Erik */
1840
String *field_term,*enclosed,*line_term,*line_start,*escaped;
1844
const CHARSET_INFO *cs;
1845
sql_exchange(char *name, bool dumpfile_flag,
1846
enum_filetype filetype_arg= FILETYPE_CSV);
1849
#include "log_event.h"
1852
This is used to get result from a select
1857
class select_result :public Sql_alloc {
1860
SELECT_LEX_UNIT *unit;
1863
virtual ~select_result() {};
1864
virtual int prepare(List<Item> &,
1870
virtual int prepare2(void) { return 0; }
1872
Because of peculiarities of prepared statements protocol
1873
we need to know number of columns in the result set (if
1874
there is a result set) apart from sending columns metadata.
1876
virtual uint32_t field_count(List<Item> &fields) const
1877
{ return fields.elements; }
1878
virtual bool send_fields(List<Item> &list, uint32_t flags)=0;
1879
virtual bool send_data(List<Item> &items)=0;
1880
virtual bool initialize_tables (JOIN *)
1882
virtual void send_error(uint32_t errcode,const char *err);
1883
virtual bool send_eof()=0;
1885
Check if this query returns a result set and therefore is allowed in
1886
cursors and set an error message if it is not the case.
1888
@retval false success
1889
@retval true error, an error message is set
1891
virtual bool check_simple_select() const;
1892
virtual void abort() {}
1894
Cleanup instance of this class for next execution of a prepared
1895
statement/stored procedure.
1897
virtual void cleanup();
1898
void set_session(Session *session_arg) { session= session_arg; }
1899
void begin_dataset() {}
1904
Base class for select_result descendands which intercept and
1905
transform result set rows. As the rows are not sent to the client,
1906
sending of result set metadata should be suppressed as well.
1909
class select_result_interceptor: public select_result
1912
select_result_interceptor() {} /* Remove gcc warning */
1913
uint32_t field_count(List<Item> &) const
1915
bool send_fields(List<Item> &,
1921
class select_send :public select_result {
1923
True if we have sent result set metadata to the client.
1924
In this case the client always expects us to end the result
1925
set with an eof or error packet
1927
bool is_result_set_started;
1929
select_send() :is_result_set_started(false) {}
1930
bool send_fields(List<Item> &list, uint32_t flags);
1931
bool send_data(List<Item> &items);
1933
virtual bool check_simple_select() const { return false; }
1935
virtual void cleanup();
1939
class select_to_file :public select_result_interceptor {
1941
sql_exchange *exchange;
1945
char path[FN_REFLEN];
1948
select_to_file(sql_exchange *ex) :exchange(ex), file(-1),row_count(0L)
1951
void send_error(uint32_t errcode,const char *err);
1500
1957
#define ESCAPE_CHARS "ntrb0ZN" // keep synchronous with READ_INFO::unescape
1502
} /* namespace drizzled */
1504
/** @TODO why is this in the middle of the file */
1505
#include <drizzled/select_to_file.h>
1506
#include <drizzled/select_export.h>
1507
#include <drizzled/select_dump.h>
1508
#include <drizzled/select_insert.h>
1509
#include <drizzled/select_create.h>
1510
#include <drizzled/tmp_table_param.h>
1511
#include <drizzled/select_union.h>
1512
#include <drizzled/select_subselect.h>
1513
#include <drizzled/select_singlerow_subselect.h>
1514
#include <drizzled/select_max_min_finder_subselect.h>
1515
#include <drizzled/select_exists_subselect.h>
1521
* A structure used to describe sort information
1522
* for a field or item used in ORDER BY.
1524
typedef struct st_sort_field
1526
Field *field; /**< Field to sort */
1527
Item *item; /**< Item if not sorting fields */
1528
size_t length; /**< Length of sort field */
1529
uint32_t suffix_length; /**< Length suffix (0-4) */
1530
Item_result result_type; /**< Type of item */
1531
bool reverse; /**< if descending sort */
1532
bool need_strxnfrm; /**< If we have to use strxnfrm() */
1961
List of all possible characters of a numeric value text representation.
1963
#define NUMERIC_CHARS ".0123456789e+-"
1966
class select_export :public select_to_file {
1967
uint32_t field_term_length;
1968
int field_sep_char,escape_char,line_sep_char;
1969
int field_term_char; // first char of FIELDS TERMINATED BY or MAX_INT
1971
The is_ambiguous_field_sep field is true if a value of the field_sep_char
1972
field is one of the 'n', 't', 'r' etc characters
1973
(see the READ_INFO::unescape method and the ESCAPE_CHARS constant value).
1975
bool is_ambiguous_field_sep;
1977
The is_ambiguous_field_term is true if field_sep_char contains the first
1978
char of the FIELDS TERMINATED BY (ENCLOSED BY is empty), and items can
1979
contain this character.
1981
bool is_ambiguous_field_term;
1983
The is_unsafe_field_sep field is true if a value of the field_sep_char
1984
field is one of the '0'..'9', '+', '-', '.' and 'e' characters
1985
(see the NUMERIC_CHARS constant value).
1987
bool is_unsafe_field_sep;
1988
bool fixed_row_size;
1990
select_export(sql_exchange *ex) :select_to_file(ex) {}
1992
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
1993
bool send_data(List<Item> &items);
1997
class select_dump :public select_to_file {
1999
select_dump(sql_exchange *ex) :select_to_file(ex) {}
2000
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2001
bool send_data(List<Item> &items);
2005
class select_insert :public select_result_interceptor {
2007
TableList *table_list;
2010
uint64_t autoinc_value_of_last_inserted_row; // autogenerated or not
2012
bool insert_into_view;
2013
select_insert(TableList *table_list_par,
2014
Table *table_par, List<Item> *fields_par,
2015
List<Item> *update_fields, List<Item> *update_values,
2016
enum_duplicates duplic, bool ignore);
2018
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2019
virtual int prepare2(void);
2020
bool send_data(List<Item> &items);
2021
virtual void store_values(List<Item> &values);
2022
virtual bool can_rollback_data() { return 0; }
2023
void send_error(uint32_t errcode,const char *err);
2026
/* not implemented: select_insert is never re-used in prepared statements */
2031
class select_create: public select_insert {
2033
TableList *create_table;
2034
HA_CREATE_INFO *create_info;
2035
TableList *select_tables;
2036
Alter_info *alter_info;
2038
/* lock data for tmp table */
2039
DRIZZLE_LOCK *m_lock;
2040
/* m_lock or session->extra_lock */
2041
DRIZZLE_LOCK **m_plock;
2043
select_create (TableList *table_arg,
2044
HA_CREATE_INFO *create_info_par,
2045
Alter_info *alter_info_arg,
2046
List<Item> &select_fields,enum_duplicates duplic, bool ignore,
2047
TableList *select_tables_arg)
2048
:select_insert (NULL, NULL, &select_fields, 0, 0, duplic, ignore),
2049
create_table(table_arg),
2050
create_info(create_info_par),
2051
select_tables(select_tables_arg),
2052
alter_info(alter_info_arg),
2055
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2057
void binlog_show_create_table(Table **tables, uint32_t count);
2058
void store_values(List<Item> &values);
2059
void send_error(uint32_t errcode,const char *err);
2062
virtual bool can_rollback_data() { return 1; }
2064
// Needed for access from local class MY_HOOKS in prepare(), since session is proteted.
2065
const Session *get_session(void) { return session; }
2066
const HA_CREATE_INFO *get_create_info() { return create_info; };
2067
int prepare2(void) { return 0; }
2070
#include <storage/myisam/myisam.h>
2073
Param to create temporary tables when doing SELECT:s
2075
This structure is copied using memcpy as a part of JOIN.
2078
class TMP_TABLE_PARAM :public Sql_alloc
2081
/* Prevent use of these (not safe because of lists and copy_field) */
2082
TMP_TABLE_PARAM(const TMP_TABLE_PARAM &);
2083
void operator=(TMP_TABLE_PARAM &);
2086
List<Item> copy_funcs;
2087
List<Item> save_copy_funcs;
2088
Copy_field *copy_field, *copy_field_end;
2089
Copy_field *save_copy_field, *save_copy_field_end;
2090
unsigned char *group_buff;
2091
Item **items_to_copy; /* Fields in tmp table */
2092
MI_COLUMNDEF *recinfo,*start_recinfo;
2094
ha_rows end_write_records;
2095
uint field_count,sum_func_count,func_count;
2096
uint32_t hidden_field_count;
2097
uint group_parts,group_length,group_null_parts;
2099
bool using_indirect_summary_function;
2100
/* If >0 convert all blob fields to varchar(convert_blob_length) */
2101
uint32_t convert_blob_length;
2102
const CHARSET_INFO *table_charset;
2105
True if GROUP BY and its aggregate functions are already computed
2106
by a table access method (e.g. by loose index scan). In this case
2107
query execution should not perform aggregation and should treat
2108
aggregate functions as normal functions.
2110
bool precomputed_group_by;
2111
bool force_copy_fields;
2113
If true, create_tmp_field called from create_tmp_table will convert
2114
all BIT fields to 64-bit longs. This is a workaround the limitation
2115
that MEMORY tables cannot index BIT columns.
2117
bool bit_fields_as_long;
2120
:copy_field(0), group_parts(0),
2121
group_length(0), group_null_parts(0), convert_blob_length(0),
2122
schema_table(0), precomputed_group_by(0), force_copy_fields(0),
2123
bit_fields_as_long(0)
2130
inline void cleanup(void)
2132
if (copy_field) /* Fix for Intel compiler */
2134
delete [] copy_field;
2135
save_copy_field= copy_field= 0;
2140
class select_union :public select_result_interceptor
2142
TMP_TABLE_PARAM tmp_table_param;
2146
select_union() :table(0) {}
2147
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2148
bool send_data(List<Item> &items);
2152
bool create_result_table(Session *session, List<Item> *column_types,
2153
bool is_distinct, uint64_t options,
2154
const char *alias, bool bit_fields_as_long);
2157
/* Base subselect interface class */
2158
class select_subselect :public select_result_interceptor
2161
Item_subselect *item;
2163
select_subselect(Item_subselect *item);
2164
bool send_data(List<Item> &items)=0;
2165
bool send_eof() { return 0; };
2168
/* Single value subselect interface class */
2169
class select_singlerow_subselect :public select_subselect
2172
select_singlerow_subselect(Item_subselect *item_arg)
2173
:select_subselect(item_arg)
2175
bool send_data(List<Item> &items);
2178
/* used in independent ALL/ANY optimisation */
2179
class select_max_min_finder_subselect :public select_subselect
2182
bool (select_max_min_finder_subselect::*op)();
2185
select_max_min_finder_subselect(Item_subselect *item_arg, bool mx)
2186
:select_subselect(item_arg), cache(0), fmax(mx)
2189
bool send_data(List<Item> &items);
2196
/* EXISTS subselect interface class */
2197
class select_exists_subselect :public select_subselect
2200
select_exists_subselect(Item_subselect *item_arg)
2201
:select_subselect(item_arg){}
2202
bool send_data(List<Item> &items);
2205
/* Structs used when sorting */
2207
typedef struct st_sort_field {
2208
Field *field; /* Field to sort */
2209
Item *item; /* Item if not sorting fields */
2210
uint length; /* Length of sort field */
2211
uint32_t suffix_length; /* Length suffix (0-4) */
2212
Item_result result_type; /* Type of item */
2213
bool reverse; /* if descending sort */
2214
bool need_strxnfrm; /* If we have to use strxnfrm() */
1535
typedef struct st_sort_buffer
1537
uint32_t index; /* 0 or 1 */
2218
typedef struct st_sort_buffer {
2219
uint32_t index; /* 0 or 1 */
1538
2220
uint32_t sort_orders;
1539
uint32_t change_pos; /* If sort-fields changed */
2221
uint32_t change_pos; /* If sort-fields changed */
1541
2223
SORT_FIELD *sortorder;
1544
} /* namespace drizzled */
1546
/** @TODO why is this in the middle of the file */
1548
#include <drizzled/table_ident.h>
1549
#include <drizzled/user_var_entry.h>
1550
#include <drizzled/unique.h>
1551
#include <drizzled/var.h>
1552
#include <drizzled/select_dumpvar.h>
2226
/* Structure for db & table in sql_yacc */
2228
class Table_ident :public Sql_alloc
2233
SELECT_LEX_UNIT *sel;
2234
inline Table_ident(Session *session, LEX_STRING db_arg, LEX_STRING table_arg,
2236
:table(table_arg), sel((SELECT_LEX_UNIT *)0)
2238
if (!force && (session->client_capabilities & CLIENT_NO_SCHEMA))
2243
inline Table_ident(LEX_STRING table_arg)
2244
:table(table_arg), sel((SELECT_LEX_UNIT *)0)
2249
This constructor is used only for the case when we create a derived
2250
table. A derived table has no name and doesn't belong to any database.
2251
Later, if there was an alias specified for the table, it will be set
2252
by add_table_to_list.
2254
inline Table_ident(SELECT_LEX_UNIT *s) : sel(s)
2256
/* We must have a table name here as this is used with add_table_to_list */
2257
db.str= empty_c_string; /* a subject to casedn_str */
2259
table.str= internal_table_name;
2262
bool is_derived_table() const { return test(sel); }
2263
inline void change_db(char *db_name)
2265
db.str= db_name; db.length= (uint) strlen(db_name);
2269
// this is needed for user_vars hash
2270
class user_var_entry
2273
user_var_entry() {} /* Remove gcc warning */
2277
query_id_t update_query_id, used_query_id;
2281
double val_real(bool *null_value);
2282
int64_t val_int(bool *null_value) const;
2283
String *val_str(bool *null_value, String *str, uint32_t decimals);
2284
my_decimal *val_decimal(bool *null_value, my_decimal *result);
2285
DTCollation collation;
2289
Unique -- class for unique (removing of duplicates).
2290
Puts all values to the TREE. If the tree becomes too big,
2291
it's dumped to the file. User can request sorted values, or
2292
just iterate through them. In the last case tree merging is performed in
2293
memory simultaneously with iteration, so it should be ~2-3x faster.
2296
class Unique :public Sql_alloc
2298
DYNAMIC_ARRAY file_ptrs;
2300
uint64_t max_in_memory_size;
2303
unsigned char *record_pointers;
2309
Unique(qsort_cmp2 comp_func, void *comp_func_fixed_arg,
2310
uint32_t size_arg, uint64_t max_in_memory_size_arg);
2312
ulong elements_in_tree() { return tree.elements_in_tree; }
2313
inline bool unique_add(void *ptr)
2315
if (tree.elements_in_tree > max_elements && flush())
2317
return(!tree_insert(&tree, ptr, 0, tree.custom_arg));
2320
bool get(Table *table);
2321
static double get_use_cost(uint32_t *buffer, uint32_t nkeys, uint32_t key_size,
2322
uint64_t max_in_memory_size);
2323
inline static int get_cost_calc_buff_size(ulong nkeys, uint32_t key_size,
2324
uint64_t max_in_memory_size)
2326
register uint64_t max_elems_in_tree=
2327
(1 + max_in_memory_size / ALIGN_SIZE(sizeof(TREE_ELEMENT)+key_size));
2328
return (int) (sizeof(uint)*(1 + nkeys/max_elems_in_tree));
2332
bool walk(tree_walk_action action, void *walk_action_arg);
2334
friend int unique_write_to_file(unsigned char* key, element_count count, Unique *unique);
2335
friend int unique_write_to_ptrs(unsigned char* key, element_count count, Unique *unique);
2339
class multi_delete :public select_result_interceptor
2341
TableList *delete_tables, *table_being_deleted;
2343
ha_rows deleted, found;
2344
uint32_t num_of_tables;
2347
/* True if at least one table we delete from is transactional */
2348
bool transactional_tables;
2349
/* True if at least one table we delete from is not transactional */
2351
bool delete_while_scanning;
2353
error handling (rollback and binlogging) can happen in send_eof()
2354
so that afterward send_error() needs to find out that.
2359
multi_delete(TableList *dt, uint32_t num_of_tables);
2361
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2362
bool send_data(List<Item> &items);
2363
bool initialize_tables (JOIN *join);
2364
void send_error(uint32_t errcode,const char *err);
2367
virtual void abort();
2371
class multi_update :public select_result_interceptor
2373
TableList *all_tables; /* query/update command tables */
2374
TableList *leaves; /* list of leves of join table tree */
2375
TableList *update_tables, *table_being_updated;
2376
Table **tmp_tables, *main_table, *table_to_update;
2377
TMP_TABLE_PARAM *tmp_table_param;
2378
ha_rows updated, found;
2379
List <Item> *fields, *values;
2380
List <Item> **fields_for_table, **values_for_table;
2381
uint32_t table_count;
2383
List of tables referenced in the CHECK OPTION condition of
2384
the updated view excluding the updated table.
2386
List <Table> unupdated_check_opt_tables;
2387
Copy_field *copy_field;
2388
enum enum_duplicates handle_duplicates;
2389
bool do_update, trans_safe;
2390
/* True if the update operation has made a change in a transactional table */
2391
bool transactional_tables;
2394
error handling (rollback and binlogging) can happen in send_eof()
2395
so that afterward send_error() needs to find out that.
2400
multi_update(TableList *ut, TableList *leaves_list,
2401
List<Item> *fields, List<Item> *values,
2402
enum_duplicates handle_duplicates, bool ignore);
2404
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2405
bool send_data(List<Item> &items);
2406
bool initialize_tables (JOIN *join);
2407
void send_error(uint32_t errcode,const char *err);
2410
virtual void abort();
2413
class my_var : public Sql_alloc {
2418
enum_field_types type;
2419
my_var (LEX_STRING& j, bool i, uint32_t o, enum_field_types t)
2420
:s(j), local(i), offset(o), type(t)
2425
class select_dumpvar :public select_result_interceptor {
2428
List<my_var> var_list;
2429
select_dumpvar() { var_list.empty(); row_count= 0;}
2430
~select_dumpvar() {}
2431
int prepare(List<Item> &list, SELECT_LEX_UNIT *u);
2432
bool send_data(List<Item> &items);
2434
virtual bool check_simple_select() const;
1557
2438
/* Bits in sql_command_flags */
1559
enum sql_command_flag_bits
1561
CF_BIT_CHANGES_DATA,
1562
CF_BIT_HAS_ROW_COUNT,
1563
CF_BIT_STATUS_COMMAND,
1564
CF_BIT_SHOW_TABLE_COMMAND,
1565
CF_BIT_WRITE_LOGS_COMMAND,
1569
static const std::bitset<CF_BIT_SIZE> CF_CHANGES_DATA(1 << CF_BIT_CHANGES_DATA);
1570
static const std::bitset<CF_BIT_SIZE> CF_HAS_ROW_COUNT(1 << CF_BIT_HAS_ROW_COUNT);
1571
static const std::bitset<CF_BIT_SIZE> CF_STATUS_COMMAND(1 << CF_BIT_STATUS_COMMAND);
1572
static const std::bitset<CF_BIT_SIZE> CF_SHOW_TABLE_COMMAND(1 << CF_BIT_SHOW_TABLE_COMMAND);
1573
static const std::bitset<CF_BIT_SIZE> CF_WRITE_LOGS_COMMAND(1 << CF_BIT_WRITE_LOGS_COMMAND);
2440
#define CF_CHANGES_DATA 1
2441
#define CF_HAS_ROW_COUNT 2
2442
#define CF_STATUS_COMMAND 4
2443
#define CF_SHOW_TABLE_COMMAND 8
2444
#define CF_WRITE_LOGS_COMMAND 16
1575
2446
/* Functions in sql_class.cc */
1576
void add_to_status(system_status_var *to_var, system_status_var *from_var);
1578
void add_diff_to_status(system_status_var *to_var, system_status_var *from_var,
1579
system_status_var *dec_var);
1581
} /* namespace drizzled */
1583
#endif /* DRIZZLED_SESSION_H */
2448
void add_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var);
2450
void add_diff_to_status(STATUS_VAR *to_var, STATUS_VAR *from_var,
2451
STATUS_VAR *dec_var);
2453
void close_connection(Session *session, uint32_t errcode, bool lock);
2455
#endif /* DRIZZLE_SERVER */
2457
#endif /* DRIZZLED_SQL_CLASS_H */