boinc/db/db_base.h

120 lines
3.0 KiB
C++

// The contents of this file are subject to the BOINC Public License
// Version 1.0 (the "License"); you may not use this file except in
// compliance with the License. You may obtain a copy of the License at
// http://boinc.berkeley.edu/license_1.0.txt
//
// Software distributed under the License is distributed on an "AS IS"
// basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
// License for the specific language governing rights and limitations
// under the License.
//
// The Original Code is the Berkeley Open Infrastructure for Network Computing.
//
// The Initial Developer of the Original Code is the SETI@home project.
// Portions created by the SETI@home project are Copyright (C) 2002
// University of California at Berkeley. All Rights Reserved.
//
// Contributor(s):
//
#ifndef _DB_BASE_
#define _DB_BASE_
#include "mysql.h"
// if SQL columns are not 'not null', you must use these safe_atoi, safe_atof
// instead of atoi, atof, since the strings returned by MySQL may be NULL.
//
inline int safe_atoi(const char* s) {
if (!s) return 0;
return atoi(s);
}
inline float safe_atof(const char* s) {
if (!s) return 0;
return atof(s);
}
#define strcpy2(x, y) \
{ \
char* z = y; \
if (!z) { \
x[0]=0; \
} else { \
strlcpy(x, z, sizeof(x)); \
} \
}
#define MAX_QUERY_LEN 256000
// TODO: use string for queries, get rid of this
struct CURSOR {
bool active;
MYSQL_RES *rp;
CURSOR() { active = false; rp = NULL; }
};
// represents a connection to a database
//
class DB_CONN {
public:
DB_CONN();
int open(char* name, char* host, char* user, char* passwd);
int do_query(char*);
void close();
int insert_id();
void print_error(char*);
const char* error_string();
MYSQL* mysql;
int start_transaction();
int commit_transaction();
};
// Base for derived classes that can access the DB
// Defines various generic operations on DB tables
//
class DB_BASE {
public:
DB_BASE(char *table_name, DB_CONN*);
int insert();
int insert_batch(std::string&);
int update();
int update_field(char*);
int delete_from_db();
int get_field_int(char*, int&);
int lookup_id(int id);
int lookup(char*);
int enumerate(char* clause="", bool use_use_result=false);
int end_enumerate();
int count(int&, char* clause="");
int sum(double&, char* field, char* clause="");
int get_double(char* query, double&);
int get_integer(char* query, int&);
bool is_high_priority;
DB_CONN* db;
const char *table_name;
CURSOR cursor;
virtual int get_id();
virtual void db_print(char*);
virtual void db_parse(MYSQL_ROW&);
};
// Base for derived classes that can get special-purpose data,
// perhaps spanning multiple tables
//
class DB_BASE_SPECIAL {
public:
DB_BASE_SPECIAL(DB_CONN*);
DB_CONN* db;
CURSOR cursor;
};
void escape_string(char* field, int len);
void unescape_string(char* p, int len);
#endif