2003-08-31 05:33:59 +00:00
|
|
|
// 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_
|
|
|
|
|
2003-08-31 01:21:31 +00:00
|
|
|
#include "mysql.h"
|
|
|
|
|
|
|
|
struct CURSOR {
|
|
|
|
bool active;
|
|
|
|
MYSQL_RES *rp;
|
|
|
|
};
|
|
|
|
|
|
|
|
// 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);
|
|
|
|
int insert();
|
|
|
|
int update();
|
|
|
|
int lookup_id(int id);
|
|
|
|
int lookup(char*);
|
|
|
|
int enumerate(char* clause="");
|
|
|
|
int count(int&, char* clause="");
|
|
|
|
int sum(double&, char* field, char* clause="");
|
|
|
|
int get_double(char* query, double&);
|
|
|
|
int get_integer(char* query, int&);
|
|
|
|
|
|
|
|
const char *table_name;
|
|
|
|
CURSOR cursor;
|
|
|
|
virtual int get_id();
|
|
|
|
virtual void db_print(char*);
|
|
|
|
virtual void db_parse(MYSQL_ROW&);
|
|
|
|
};
|
|
|
|
|
2003-08-31 05:33:59 +00:00
|
|
|
void strcpy2(char* dest, char* src);
|
|
|
|
void escape_single_quotes(char* field);
|
|
|
|
void unescape_single_quotes(char* p);
|
|
|
|
|
|
|
|
#endif
|