#ifndef QUERY_BUILDER_H #define QUERY_BUILDER_H #include "core/ustring.h" #include "core/reference.h" class QueryResult; //methods that start with an e escape their params. class QueryBuilder : public Reference { GDCLASS(QueryBuilder, Reference); public: virtual QueryBuilder *select(); virtual QueryBuilder *update(); virtual QueryBuilder *del(); virtual QueryBuilder *cvalues(); virtual QueryBuilder *next_value(); virtual QueryBuilder *begin_transaction(); virtual QueryBuilder *commit(); virtual QueryBuilder *nl(); virtual QueryBuilder *str(); virtual QueryBuilder *cstr(); virtual QueryBuilder *select(const String ¶ms); virtual QueryBuilder *update(const String ¶ms); virtual QueryBuilder *del(const String ¶ms); virtual QueryBuilder *where(const String ¶ms = ""); virtual QueryBuilder *from(const String ¶ms = ""); virtual QueryBuilder *insert(const String &table_name = "", const String &columns = ""); virtual QueryBuilder *values(const String ¶ms_str = ""); virtual QueryBuilder *val(); virtual QueryBuilder *vals(const String ¶m); virtual QueryBuilder *vals(const char *param); virtual QueryBuilder *vali(const int param); virtual QueryBuilder *valb(const bool param); virtual QueryBuilder *valf(const float param); virtual QueryBuilder *vald(const double param); virtual QueryBuilder *like(const String &str = ""); //Object Already has set(), so think of it as set_sql virtual QueryBuilder *sets(); virtual QueryBuilder *cset(); virtual QueryBuilder *setps(const String &col, const String ¶m); virtual QueryBuilder *setps(const String &col, const char *param); virtual QueryBuilder *setpi(const String &col, const int param); virtual QueryBuilder *setpb(const String &col, const bool param); virtual QueryBuilder *setpf(const String &col, const float param); virtual QueryBuilder *setpd(const String &col, const double param); virtual QueryBuilder *wps(const String &col, const String ¶m); virtual QueryBuilder *wps(const String &col, const char *param); virtual QueryBuilder *wpi(const String &col, const int param); virtual QueryBuilder *wpb(const String &col, const bool param); virtual QueryBuilder *nselect(const String ¶ms); virtual QueryBuilder *nupdate(const String ¶ms); virtual QueryBuilder *ndel(const String ¶ms); virtual QueryBuilder *nwhere(const String ¶ms); virtual QueryBuilder *nfrom(const String ¶ms); virtual QueryBuilder *nlike(const String &str); virtual QueryBuilder *nvalues(const String ¶ms_str); virtual QueryBuilder *nval(const String ¶m); //note col is NOT escaped virtual QueryBuilder *nsetp(const String &col, const String &escape_param); //note col is NOT escaped virtual QueryBuilder *nwp(const String &col, const String &escape_param); virtual QueryBuilder *limit(const int num); virtual QueryBuilder *offset(const int num); virtual QueryBuilder *order_by_asc(const String &col); virtual QueryBuilder *order_by_desc(const String &col); virtual QueryBuilder *order_by(const String &col = ""); virtual QueryBuilder *corder_by(); virtual QueryBuilder *order_by_add_col(const String &col); virtual QueryBuilder *asc(const String &col = ""); virtual QueryBuilder *desc(const String &col = ""); //l=logical (and, or are operators) virtual QueryBuilder *land(); virtual QueryBuilder *lor(); virtual QueryBuilder *wildcard(); virtual QueryBuilder *w(const String &str); virtual QueryBuilder *ew(const String &str); virtual QueryBuilder *select_last_insert_id(); virtual String escape(const String ¶ms); virtual QueryBuilder *prepare(); virtual QueryBuilder *set_params(const int index, const String &value); virtual QueryBuilder *set_parami(const int index, const int value); virtual QueryBuilder *set_paramf(const int index, const float value); virtual QueryBuilder *end_command(); virtual QueryBuilder *reset(); virtual Ref run(); virtual void run_query(); String get_result(); void print(); QueryBuilder(); virtual ~QueryBuilder(); String query_result; protected: static void _bind_methods(); Ref _cvalues_bind(); Ref _next_value_bind(); Ref _begin_transaction_bind(); Ref _commit_bind(); Ref _nl_bind(); Ref _str_bind(); Ref _cstr_bind(); Ref _select_bind(const String ¶ms); Ref _update_bind(const String ¶ms); Ref _del_bind(const String ¶ms); Ref _where_bind(const String ¶ms = ""); Ref _from_bind(const String ¶ms = ""); Ref _insert_bind(const String &table_name = "", const String &columns = ""); Ref _values_bind(const String ¶ms_str = ""); Ref _val_bind(); Ref _vals_bind(const String ¶m); Ref _vali_bind(const int param); Ref _valb_bind(const bool param); Ref _valf_bind(const float param); Ref _vald_bind(const double param); Ref _like_bind(const String &str); Ref _sets_bind(); Ref _cset_bind(); Ref _setps_bind(const String &col, const String ¶m); Ref _setpi_bind(const String &col, const int param); Ref _setpb_bind(const String &col, const bool param); Ref _setpf_bind(const String &col, const float param); Ref _setpd_bind(const String &col, const double param); Ref _wps_bind(const String &col, const String ¶m); Ref _wpi_bind(const String &col, const int param); Ref _wpb_bind(const String &col, const bool param); Ref _nselect_bind(const String ¶ms); Ref _nupdate_bind(const String ¶ms); Ref _ndel_bind(const String ¶ms); Ref _nwhere_bind(const String ¶ms); Ref _nfrom_bind(const String ¶ms); Ref _nlike_bind(const String &str); Ref _nvalues_bind(const String ¶ms_str); Ref _nval_bind(const String ¶m); //note col is NOT escaped Ref _nsetp_bind(const String &col, const String &escape_param); //note col is NOT escaped Ref _nwp_bind(const String &col, const String &escape_param); Ref _limit_bind(const int num); Ref _offset_bind(const int num); Ref _order_by_asc_bind(const String &col); Ref _order_by_desc_bind(const String &col); Ref _order_by_bind(const String &col = ""); Ref _corder_by_bind(); Ref _order_by_add_col_bind(const String &col); Ref _asc_bind(const String &col = ""); Ref _desc_bind(const String &col = ""); //l=logical (and, or are operators) Ref _land_bind(); Ref _lor_bind(); Ref _wildcard_bind(); Ref _w_bind(const String &str); Ref _ew_bind(const String &str); Ref _select_last_insert_id_bind(); Ref _prepare_bind(); Ref _set_params_bind(const int index, const String &value); Ref _set_parami_bind(const int index, const int value); Ref _set_paramf_bind(const int index, const float value); Ref _end_command_bind(); Ref _reset_bind(); }; #endif