MIDAS
Loading...
Searching...
No Matches
SqlHistoryBase Class Referenceabstract
Inheritance diagram for SqlHistoryBase:
Collaboration diagram for SqlHistoryBase:

Public Member Functions

 SqlHistoryBase ()
 
virtual ~SqlHistoryBase ()
 
int hs_set_debug (int debug)
 set debug level, returns previous debug level
 
int hs_connect (const char *connect_string)
 returns HS_SUCCESS
 
int hs_disconnect ()
 disconnect from history, returns HS_SUCCESS
 
HsSchemanew_event (const char *event_name, time_t timestamp, int ntags, const TAG tags[])
 
int read_schema (HsSchemaVector *sv, const char *event_name, const time_t timestamp)
 
HsSchemamaybe_reopen (const char *event_name, time_t timestamp, HsSchema *s)
 
- Public Member Functions inherited from SchemaHistoryBase
 SchemaHistoryBase ()
 
virtual ~SchemaHistoryBase ()
 
int hs_define_event (const char *event_name, time_t timestamp, int ntags, const TAG tags[])
 see hs_define_event(), returns HS_SUCCESS or HS_FILE_ERROR
 
int hs_write_event (const char *event_name, time_t timestamp, int buffer_size, const char *buffer)
 see hs_write_event(), returns HS_SUCCESS or HS_FILE_ERROR
 
int hs_flush_buffers ()
 flush buffered data to storage where it is visible to mhttpd
 
int hs_clear_cache ()
 clear internal cache, returns HS_SUCCESS
 
int hs_get_events (time_t t, std::vector< std::string > *pevents)
 get list of events that exist(ed) at given time and later (value 0 means "return all events from beginning of time"), returns HS_SUCCESS
 
int hs_get_tags (const char *event_name, time_t t, std::vector< TAG > *ptags)
 get list of history variables for given event (use event names returned by hs_get_events()) that exist(ed) at given time and later (value 0 means "all variables for this event that ever existed"), also see hs_get_tags(), returns HS_SUCCESS
 
int hs_get_last_written (time_t timestamp, int num_var, const char *const event_name[], const char *const var_name[], const int var_index[], time_t last_written[])
 
int hs_read_buffer (time_t start_time, time_t end_time, int num_var, const char *const event_name[], const char *const var_name[], const int var_index[], MidasHistoryBufferInterface *buffer[], int hs_status[])
 returns HS_SUCCESS
 
int hs_read (time_t start_time, time_t end_time, time_t interval, int num_var, const char *const event_name[], const char *const var_name[], const int var_index[], int num_entries[], time_t *time_buffer[], double *data_buffer[], int st[])
 see hs_read(), returns HS_SUCCESS
 
int hs_read_binned (time_t start_time, time_t end_time, int num_bins, int num_var, const char *const event_name[], const char *const var_name[], const int var_index[], int num_entries[], int *count_bins[], double *mean_bins[], double *rms_bins[], double *min_bins[], double *max_bins[], time_t *bins_first_time[], double *bins_first_value[], time_t *bins_last_time[], double *bins_last_value[], time_t last_time[], double last_value[], int st[])
 returns HS_SUCCESS
 
- Public Member Functions inherited from MidasHistoryInterface
 MidasHistoryInterface ()
 history type: MIDAS, ODBC, SQLITE, etc
 
virtual ~MidasHistoryInterface ()
 

Public Attributes

SqlBasefSql
 
- Public Attributes inherited from MidasHistoryInterface
char name [NAME_LENGTH]
 
char type [NAME_LENGTH]
 history channel name
 

Protected Member Functions

virtual int read_table_and_event_names (HsSchemaVector *sv)=0
 
virtual int read_column_names (HsSchemaVector *sv, const char *table_name, const char *event_name)=0
 
virtual int create_table (HsSchemaVector *sv, const char *event_name, time_t timestamp)=0
 
virtual int update_column (const char *event_name, const char *table_name, const char *column_name, const char *column_type, const char *tag_name, const char *tag_type, const time_t timestamp, bool active, bool *have_transaction)=0
 
int update_schema (HsSqlSchema *s, const time_t timestamp, const int ntags, const TAG tags[], bool write_enable)
 
int update_schema1 (HsSqlSchema *s, const time_t timestamp, const int ntags, const TAG tags[], bool write_enable, bool *have_transaction)
 

Additional Inherited Members

- Protected Attributes inherited from SchemaHistoryBase
int fDebug = 0
 
std::string fConnectString
 
HsSchemaVector fWriterSchema
 
std::vector< HsSchema * > fWriterEvents
 
HsSchemaVector fReaderSchema
 

Detailed Description

Definition at line 4778 of file history_schema.cxx.

Constructor & Destructor Documentation

◆ SqlHistoryBase()

SqlHistoryBase::SqlHistoryBase ( )
inline

Definition at line 4783 of file history_schema.cxx.

4784 {
4785 fSql = NULL;
4787 }
int hs_clear_cache()
clear internal cache, returns HS_SUCCESS
TH1X EXPRT * h1_book(const char *name, const char *title, int bins, double min, double max)
Definition rmidas.h:24
Here is the call graph for this function:

◆ ~SqlHistoryBase()

virtual SqlHistoryBase::~SqlHistoryBase ( )
inlinevirtual

Definition at line 4789 of file history_schema.cxx.

4790 {
4791 hs_disconnect();
4792 if (fSql)
4793 delete fSql;
4794 fSql = NULL;
4795 }
int hs_disconnect()
disconnect from history, returns HS_SUCCESS
Here is the call graph for this function:

Member Function Documentation

◆ create_table()

virtual int SqlHistoryBase::create_table ( HsSchemaVector sv,
const char event_name,
time_t  timestamp 
)
protectedpure virtual

Implemented in SqliteHistory, and MysqlHistory.

Here is the caller graph for this function:

◆ hs_connect()

int SqlHistoryBase::hs_connect ( const char connect_string)
virtual

returns HS_SUCCESS

Implements SchemaHistoryBase.

Definition at line 4821 of file history_schema.cxx.

4822{
4823 if (fDebug)
4824 printf("hs_connect [%s]!\n", connect_string);
4825
4826 assert(fSql);
4827
4828 if (fSql->IsConnected())
4829 if (strcmp(fConnectString.c_str(), connect_string) == 0)
4830 return HS_SUCCESS;
4831
4832 hs_disconnect();
4833
4834 if (!connect_string || strlen(connect_string) < 1) {
4835 // FIXME: should use "logger dir" or some such default, that code should be in hs_get_history(), not here
4836 connect_string = ".";
4837 }
4838
4840
4841 if (fDebug)
4842 printf("hs_connect: connecting to SQL database \'%s\'\n", fConnectString.c_str());
4843
4844 int status = fSql->Connect(fConnectString.c_str());
4845 if (status != DB_SUCCESS)
4846 return status;
4847
4848 return HS_SUCCESS;
4849}
virtual bool IsConnected()=0
virtual int Connect(const char *dsn=0)=0
#define DB_SUCCESS
Definition midas.h:631
#define HS_SUCCESS
Definition midas.h:727
DWORD status
Definition odbhist.cxx:39
Here is the call graph for this function:

◆ hs_disconnect()

int SqlHistoryBase::hs_disconnect ( )
virtual

disconnect from history, returns HS_SUCCESS

Implements SchemaHistoryBase.

Definition at line 4851 of file history_schema.cxx.

4852{
4853 if (fDebug)
4854 printf("hs_disconnect!\n");
4855
4857
4858 fSql->Disconnect();
4859
4861
4862 return HS_SUCCESS;
4863}
int hs_flush_buffers()
flush buffered data to storage where it is visible to mhttpd
virtual int Disconnect()=0
Here is the call graph for this function:
Here is the caller graph for this function:

◆ hs_set_debug()

int SqlHistoryBase::hs_set_debug ( int  debug)
inlinevirtual

set debug level, returns previous debug level

Reimplemented from SchemaHistoryBase.

Definition at line 4797 of file history_schema.cxx.

4798 {
4799 if (fSql)
4800 fSql->fDebug = debug;
4802 }
virtual int hs_set_debug(int debug)
set debug level, returns previous debug level
BOOL debug
debug printouts
Definition mana.cxx:254
Here is the call graph for this function:

◆ maybe_reopen()

HsSchema * SqlHistoryBase::maybe_reopen ( const char event_name,
time_t  timestamp,
HsSchema s 
)
inlinevirtual

Implements SchemaHistoryBase.

Definition at line 4808 of file history_schema.cxx.

4808{ return s; };

◆ new_event()

HsSchema * SqlHistoryBase::new_event ( const char event_name,
time_t  timestamp,
int  ntags,
const TAG  tags[] 
)
virtual

Implements SchemaHistoryBase.

Definition at line 4865 of file history_schema.cxx.

4866{
4867 if (fDebug)
4868 printf("SqlHistory::new_event: event [%s], timestamp %s, ntags %d\n", event_name, TimeToString(timestamp).c_str(), ntags);
4869
4870 int status;
4871
4872 if (fWriterSchema.size() == 0) {
4874 if (status != HS_SUCCESS)
4875 return NULL;
4876 }
4877
4878 HsSqlSchema* s = (HsSqlSchema*)fWriterSchema.find_event(event_name, timestamp);
4879
4880 // schema does not exist, the SQL tables probably do not exist yet
4881
4882 if (!s) {
4883 status = create_table(&fWriterSchema, event_name, timestamp);
4884 if (status != HS_SUCCESS)
4885 return NULL;
4886
4887 s = (HsSqlSchema*)fWriterSchema.find_event(event_name, timestamp);
4888
4889 if (!s) {
4890 cm_msg(MERROR, "SqlHistory::new_event", "Error: Cannot create schema for event \'%s\', see previous messages", event_name);
4891 fWriterSchema.find_event(event_name, timestamp, 1);
4892 return NULL;
4893 }
4894 }
4895
4896 assert(s != NULL);
4897
4898 status = read_column_names(&fWriterSchema, s->fTableName.c_str(), s->fEventName.c_str());
4899 if (status != HS_SUCCESS)
4900 return NULL;
4901
4902 s = (HsSqlSchema*)fWriterSchema.find_event(event_name, timestamp);
4903
4904 if (!s) {
4905 cm_msg(MERROR, "SqlHistory::new_event", "Error: Cannot update schema database for event \'%s\', see previous messages", event_name);
4906 return NULL;
4907 }
4908
4909 if (0||fDebug) {
4910 printf("SqlHistory::new_event: schema for [%s] is %p\n", event_name, s);
4911 if (s)
4912 s->print();
4913 }
4914
4915 status = update_schema(s, timestamp, ntags, tags, true);
4916 if (status != HS_SUCCESS) {
4917 cm_msg(MERROR, "SqlHistory::new_event", "Error: Cannot create schema for event \'%s\', see previous messages", event_name);
4918 return NULL;
4919 }
4920
4921 status = read_column_names(&fWriterSchema, s->fTableName.c_str(), s->fEventName.c_str());
4922 if (status != HS_SUCCESS)
4923 return NULL;
4924
4925 s = (HsSqlSchema*)fWriterSchema.find_event(event_name, timestamp);
4926
4927 if (!s) {
4928 cm_msg(MERROR, "SqlHistory::new_event", "Error: Cannot update schema database for event \'%s\', see previous messages", event_name);
4929 return NULL;
4930 }
4931
4932 if (0||fDebug) {
4933 printf("SqlHistory::new_event: schema for [%s] is %p\n", event_name, s);
4934 if (s)
4935 s->print();
4936 }
4937
4938 // last call to UpdateMysqlSchema with "false" will check that new schema matches the new tags
4939
4940 status = update_schema(s, timestamp, ntags, tags, false);
4941 if (status != HS_SUCCESS) {
4942 cm_msg(MERROR, "SqlHistory::new_event", "Error: Cannot create schema for event \'%s\', see previous messages", event_name);
4943 //fDebug = 1;
4944 //update_schema(s, timestamp, ntags, tags, false);
4945 //abort();
4946 return NULL;
4947 }
4948
4949 HsSqlSchema* e = new HsSqlSchema();
4950
4951 *e = *s; // make a copy of the schema
4952
4953 return e;
4954}
std::string fEventName
size_t size() const
HsSchema * find_event(const char *event_name, const time_t timestamp, int debug=0)
void print(bool print_tags=true) const
std::string fTableName
HsSchemaVector fWriterSchema
virtual int create_table(HsSchemaVector *sv, const char *event_name, time_t timestamp)=0
virtual int read_column_names(HsSchemaVector *sv, const char *table_name, const char *event_name)=0
virtual int read_table_and_event_names(HsSchemaVector *sv)=0
int update_schema(HsSqlSchema *s, const time_t timestamp, const int ntags, const TAG tags[], bool write_enable)
#define MERROR
Definition midas.h:559
INT cm_msg(INT message_type, const char *filename, INT line, const char *routine, const char *format,...)
Definition midas.cxx:929
static std::string TimeToString(time_t t)
static double e(void)
Definition tinyexpr.c:136
Here is the call graph for this function:

◆ read_column_names()

virtual int SqlHistoryBase::read_column_names ( HsSchemaVector sv,
const char table_name,
const char event_name 
)
protectedpure virtual

Implemented in SqliteHistory, and MysqlHistory.

Here is the caller graph for this function:

◆ read_schema()

int SqlHistoryBase::read_schema ( HsSchemaVector sv,
const char event_name,
const time_t  timestamp 
)
virtual

Implements SchemaHistoryBase.

Definition at line 4956 of file history_schema.cxx.

4957{
4958 if (fDebug)
4959 printf("SqlHistory::read_schema: loading schema for event [%s] at time %s\n", event_name, TimeToString(timestamp).c_str());
4960
4961 int status;
4962
4963 if (sv->size() == 0) {
4965 if (status != HS_SUCCESS)
4966 return status;
4967 }
4968
4969 //sv->print(false);
4970
4971 if (event_name == NULL)
4972 return HS_SUCCESS;
4973
4974 for (size_t i=0; i<sv->size(); i++) {
4975 HsSqlSchema* h = (HsSqlSchema*)(*sv)[i];
4976 // skip schema with already read column names
4977 if (h->fVariables.size() > 0)
4978 continue;
4979 // skip schema with different name
4980 if (!MatchEventName(h->fEventName.c_str(), event_name))
4981 continue;
4982
4983 size_t nn = sv->size();
4984
4985 status = read_column_names(sv, h->fTableName.c_str(), h->fEventName.c_str());
4986
4987 // if new schema was added, loop all over again
4988 if (sv->size() != nn)
4989 i=0;
4990 }
4991
4992 //sv->print(false);
4993
4994 return HS_SUCCESS;
4995}
std::vector< HsSchemaEntry > fVariables
static bool MatchEventName(const char *event_name, const char *var_event_name)
INT i
Definition mdump.cxx:32
Here is the call graph for this function:

◆ read_table_and_event_names()

virtual int SqlHistoryBase::read_table_and_event_names ( HsSchemaVector sv)
protectedpure virtual

Implemented in SqliteHistory, and MysqlHistory.

Here is the caller graph for this function:

◆ update_column()

virtual int SqlHistoryBase::update_column ( const char event_name,
const char table_name,
const char column_name,
const char column_type,
const char tag_name,
const char tag_type,
const time_t  timestamp,
bool  active,
bool have_transaction 
)
protectedpure virtual

Implemented in SqliteHistory, and MysqlHistory.

Here is the caller graph for this function:

◆ update_schema()

int SqlHistoryBase::update_schema ( HsSqlSchema s,
const time_t  timestamp,
const int  ntags,
const TAG  tags[],
bool  write_enable 
)
protected

Definition at line 4997 of file history_schema.cxx.

4998{
4999 int status;
5000 bool have_transaction = false;
5001
5002 status = update_schema1(s, timestamp, ntags, tags, write_enable, &have_transaction);
5003
5004 if (have_transaction) {
5005 int xstatus;
5006
5007 if (status == HS_SUCCESS)
5009 else
5011
5012 if (xstatus != DB_SUCCESS) {
5013 return HS_FILE_ERROR;
5014 }
5015 have_transaction = false;
5016 }
5017
5018 return status;
5019}
virtual int RollbackTransaction(const char *table_name)=0
virtual int CommitTransaction(const char *table_name)=0
int update_schema1(HsSqlSchema *s, const time_t timestamp, const int ntags, const TAG tags[], bool write_enable, bool *have_transaction)
#define HS_FILE_ERROR
Definition midas.h:728
Here is the call graph for this function:
Here is the caller graph for this function:

◆ update_schema1()

int SqlHistoryBase::update_schema1 ( HsSqlSchema s,
const time_t  timestamp,
const int  ntags,
const TAG  tags[],
bool  write_enable,
bool have_transaction 
)
protected

Definition at line 5021 of file history_schema.cxx.

5022{
5023 int status;
5024
5025 if (fDebug)
5026 printf("update_schema1\n");
5027
5028 // check that compare schema with tags[]
5029
5030 bool schema_ok = true;
5031
5032 int offset = 0;
5033 for (int i=0; i<ntags; i++) {
5034 for (unsigned int j=0; j<tags[i].n_data; j++) {
5035 int tagtype = tags[i].type;
5036 std::string tagname = tags[i].name;
5037 std::string maybe_colname = MidasNameToSqlName(tags[i].name);
5038
5039 if (tags[i].n_data > 1) {
5040 char s[256];
5041 sprintf(s, "[%d]", j);
5042 tagname += s;
5043
5044 sprintf(s, "_%d", j);
5045 maybe_colname += s;
5046 }
5047
5048 int count = 0;
5049
5050 for (size_t j=0; j<s->fVariables.size(); j++) {
5051 // NB: inactive columns will be reactivated or recreated by the if(count==0) branch. K.O.
5052 if (s->fColumnInactive[j])
5053 continue;
5054 if (tagname == s->fVariables[j].name) {
5055 if (s->fSql->TypesCompatible(tagtype, s->fColumnTypes[j].c_str())) {
5056 if (count == 0) {
5057 s->fOffsets[j] = offset;
5059 }
5060 count++;
5061 if (count > 1) {
5062 cm_msg(MERROR, "SqlHistory::update_schema", "Duplicate SQL column \'%s\' type \'%s\' in table \"%s\" with MIDAS type \'%s\' history event \"%s\" tag \"%s\"", s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fTableName.c_str(), rpc_tid_name(tagtype), s->fEventName.c_str(), tagname.c_str());
5064 }
5065 } else {
5066 // column with incompatible type, mark it as unused
5067 schema_ok = false;
5068 if (fDebug)
5069 printf("Incompatible column!\n");
5070 if (write_enable) {
5071 cm_msg(MINFO, "SqlHistory::update_schema", "Deactivating SQL column \'%s\' type \'%s\' in table \"%s\" as incompatible with MIDAS type \'%s\' history event \"%s\" tag \"%s\"", s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fTableName.c_str(), rpc_tid_name(tagtype), s->fEventName.c_str(), tagname.c_str());
5073
5074 status = update_column(s->fEventName.c_str(), s->fTableName.c_str(), s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fVariables[j].tag_name.c_str(), s->fVariables[i].tag_type.c_str(), timestamp, false, have_transaction);
5075 if (status != HS_SUCCESS)
5076 return status;
5077 }
5078 }
5079 }
5080 }
5081
5082 if (count == 0) {
5083 // tag does not have a corresponding column
5084 schema_ok = false;
5085 if (fDebug)
5086 printf("No column for tag %s!\n", tagname.c_str());
5087
5088 bool found_column = false;
5089
5090 if (write_enable) {
5091 for (size_t j=0; j<s->fVariables.size(); j++) {
5092 if (tagname == s->fVariables[j].tag_name) {
5093 bool typeok = s->fSql->TypesCompatible(tagtype, s->fColumnTypes[j].c_str());
5094 if (typeok) {
5095 cm_msg(MINFO, "SqlHistory::update_schema", "Reactivating SQL column \'%s\' type \'%s\' in table \"%s\" for history event \"%s\" tag \"%s\"", s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fTableName.c_str(), s->fEventName.c_str(), tagname.c_str());
5097
5098 status = update_column(s->fEventName.c_str(), s->fTableName.c_str(), s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fVariables[j].tag_name.c_str(), s->fVariables[j].tag_type.c_str(), timestamp, true, have_transaction);
5099 if (status != HS_SUCCESS)
5100 return status;
5101
5102 if (count == 0) {
5103 s->fOffsets[j] = offset;
5105 }
5106 count++;
5107 found_column = true;
5108 if (count > 1) {
5109 cm_msg(MERROR, "SqlHistory::update_schema", "Duplicate SQL column \'%s\' type \'%s\' in table \"%s\" for history event \"%s\" tag \"%s\"", s->fColumnNames[j].c_str(), s->fColumnTypes[j].c_str(), s->fTableName.c_str(), s->fEventName.c_str(), tagname.c_str());
5111 }
5112 }
5113 }
5114 }
5115 }
5116
5117 // create column
5118 if (!found_column && write_enable) {
5119 std::string col_name = maybe_colname;
5120 const char* col_type = s->fSql->ColumnType(tagtype);
5121
5122 bool dupe = false;
5123 for (size_t kk=0; kk<s->fColumnNames.size(); kk++)
5124 if (s->fColumnNames[kk] == col_name) {
5125 dupe = true;
5126 break;
5127 }
5128
5129 time_t now = time(NULL);
5130
5131 bool retry = false;
5132 for (int t=0; t<20; t++) {
5133
5134 // if duplicate column name, change it, try again
5135 if (dupe || retry) {
5137 col_name += "_";
5139 if (t > 0) {
5140 char s[256];
5141 sprintf(s, "_%d", t);
5142 col_name += s;
5143 }
5144 }
5145
5146 if (fDebug)
5147 printf("SqlHistory::update_schema: table [%s], add column [%s] type [%s] for tag [%s]\n", s->fTableName.c_str(), col_name.c_str(), col_type, tagname.c_str());
5148
5150
5151 if (status == DB_KEY_EXIST) {
5152 if (fDebug)
5153 printf("SqlHistory::update_schema: table [%s], add column [%s] type [%s] for tag [%s] failed: duplicate column name\n", s->fTableName.c_str(), col_name.c_str(), col_type, tagname.c_str());
5154 retry = true;
5155 continue;
5156 }
5157
5158 if (status != HS_SUCCESS)
5159 return status;
5160
5161 break;
5162 }
5163
5164 if (status != HS_SUCCESS)
5165 return status;
5166
5167 status = update_column(s->fEventName.c_str(), s->fTableName.c_str(), col_name.c_str(), col_type, tagname.c_str(), rpc_tid_name(tagtype), timestamp, true, have_transaction);
5168 if (status != HS_SUCCESS)
5169 return status;
5170 }
5171 }
5172
5173 if (count > 1) {
5174 // schema has duplicate tags
5175 schema_ok = false;
5176 cm_msg(MERROR, "SqlHistory::update_schema", "Duplicate tags or SQL columns for history event \"%s\" tag \"%s\"", s->fEventName.c_str(), tagname.c_str());
5178 }
5179 }
5180 }
5181
5182 // mark as unused all columns not listed in tags
5183
5184 for (size_t k=0; k<s->fColumnNames.size(); k++)
5185 if (s->fVariables[k].name.length() > 0) {
5186 bool found = false;
5187
5188 for (int i=0; i<ntags; i++) {
5189 for (unsigned int j=0; j<tags[i].n_data; j++) {
5190 std::string tagname = tags[i].name;
5191
5192 if (tags[i].n_data > 1) {
5193 char s[256];
5194 sprintf(s, "[%d]", j);
5195 tagname += s;
5196 }
5197
5198 if (s->fVariables[k].name == tagname) {
5199 found = true;
5200 break;
5201 }
5202 }
5203
5204 if (found)
5205 break;
5206 }
5207
5208 if (!found) {
5209 // column not found in tags list
5210 schema_ok = false;
5211 if (fDebug)
5212 printf("Event [%s] Column [%s] tag [%s] not listed in tags list!\n", s->fEventName.c_str(), s->fColumnNames[k].c_str(), s->fVariables[k].name.c_str());
5213 if (write_enable) {
5214 cm_msg(MINFO, "SqlHistory::update_schema", "Deactivating SQL column \'%s\' type \'%s\' in table \"%s\" for history event \"%s\" not used for any tags", s->fColumnNames[k].c_str(), s->fColumnTypes[k].c_str(), s->fTableName.c_str(), s->fEventName.c_str());
5216
5217 status = update_column(s->fEventName.c_str(), s->fTableName.c_str(), s->fColumnNames[k].c_str(), s->fColumnTypes[k].c_str(), s->fVariables[k].tag_name.c_str(), s->fVariables[k].tag_type.c_str(), timestamp, false, have_transaction);
5218 if (status != HS_SUCCESS)
5219 return status;
5220 }
5221 }
5222 }
5223
5224 if (!write_enable)
5225 if (!schema_ok) {
5226 if (fDebug)
5227 printf("Return error!\n");
5228 return HS_FILE_ERROR;
5229 }
5230
5231 return HS_SUCCESS;
5232}
std::vector< int > fOffsets
std::vector< std::string > fColumnNames
std::vector< std::string > fColumnTypes
std::vector< bool > fColumnInactive
char name[NAME_LENGTH]
Definition history.h:111
virtual bool TypesCompatible(int midas_tid, const char *sql_type)=0
virtual const char * ColumnType(int midas_tid)=0
virtual int update_column(const char *event_name, const char *table_name, const char *column_name, const char *column_type, const char *tag_name, const char *tag_type, const time_t timestamp, bool active, bool *have_transaction)=0
#define DB_KEY_EXIST
Definition midas.h:641
#define MINFO
Definition midas.h:560
INT cm_msg_flush_buffer()
Definition midas.cxx:879
const char * rpc_tid_name(INT id)
Definition midas.cxx:11786
INT rpc_tid_size(INT id)
Definition midas.cxx:11779
static std::string MidasNameToSqlName(const char *s)
static int CreateSqlColumn(SqlBase *sql, const char *table_name, const char *column_name, const char *column_type, bool *have_transaction, int debug)
double count
Definition mdump.cxx:33
static int offset
Definition mgd.cxx:1500
INT j
Definition odbhist.cxx:40
INT k
Definition odbhist.cxx:40
DWORD type
Definition midas.h:1234
DWORD n_data
Definition midas.h:1235
char name[NAME_LENGTH]
Definition midas.h:1233
Here is the call graph for this function:
Here is the caller graph for this function:

Member Data Documentation

◆ fSql

SqlBase* SqlHistoryBase::fSql

Definition at line 4781 of file history_schema.cxx.


The documentation for this class was generated from the following file: