source: gsdl/trunk/lib/sqlitedbclass.h@ 15849

Last change on this file since 15849 was 15849, checked in by mdewsnip, 16 years ago

(Adding new DB support) Adding a "sqlite_safe()" function for escaping any single quotes in values going into SQL statements, and applied this everywhere it might be required.

File size: 2.3 KB
Line 
1/**********************************************************************
2 *
3 * sqlitedbclass.h --
4 * Copyright (C) 2008 DL Consulting Ltd
5 *
6 * A component of the Greenstone digital library software
7 * from the New Zealand Digital Library Project at the
8 * University of Waikato, New Zealand.
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 *
24 *********************************************************************/
25
26#ifndef SQLITEDBCLASS_H
27#define SQLITEDBCLASS_H
28
29
30#include "sqldbclass.h"
31#include "sqlite3.h"
32
33
34class sqlitedbclass : public sqldbclass
35{
36public:
37 sqlitedbclass() { sqlitefile = NULL; }
38 ~sqlitedbclass();
39
40 // returns true if opened
41 bool opendatabase (const text_t &filename, int mode, int num_retrys, bool need_filelock);
42
43 void closedatabase ();
44
45 void deletekey (const text_t &key);
46
47 // returns array of document OIDs
48 text_tarray get_documents_with_metadata_value (const text_t &metadata_element_name,
49 const text_t &metadata_value,
50 const text_t &sort_by_metadata_element_name);
51
52 // returns file extension string
53 text_t getfileextension ();
54
55 // returns true on success
56 bool getkeydata (const text_t& key, text_t &data);
57
58 // returns array of keys
59 text_tarray getkeys ();
60
61 // returns array of values
62 text_tarray get_metadata_values (const text_t &metadata_element_name);
63
64 // returns true on success
65 bool setkeydata (const text_t &key, const text_t &data);
66
67protected:
68 text_t openfile;
69 sqlite3* sqlitefile;
70
71 text_t sqlite_safe (const text_t &value_arg);
72
73 bool sqlexec (const text_t &sql_cmd);
74 bool sqlgetarray (const text_t &sql_cmd, vector<text_tmap> &sql_results);
75 bool sqltableexists (const text_t &table_name);
76};
77
78
79#endif
Note: See TracBrowser for help on using the repository browser.