本文整理汇总了C++中SqliteDatabase::execute方法的典型用法代码示例。如果您正苦于以下问题:C++ SqliteDatabase::execute方法的具体用法?C++ SqliteDatabase::execute怎么用?C++ SqliteDatabase::execute使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SqliteDatabase
的用法示例。
在下文中一共展示了SqliteDatabase::execute方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: load
void Database_Privileges::load (string username, const string & data)
{
// Clear all data for the user.
{
SqliteDatabase sql (database ());
sql.add ("DELETE FROM bibles WHERE username =");
sql.add (username);
sql.add (";");
sql.execute ();
sql.clear ();
sql.add ("DELETE FROM features WHERE username =");
sql.add (username);
sql.add (";");
sql.execute ();
}
vector <string> lines = filter_string_explode (data, '\n');
bool loading_bibles = false;
string bible_value;
int book_value = 0;
bool write_value = false;
bool loading_features = false;
int counter = 0;
for (auto & line : lines) {
if (line == bibles_end ()) {
loading_bibles = false;
}
if (line == features_end ()) {
loading_features = false;
}
counter++;
if (loading_bibles) {
if (counter == 1) bible_value = line;
if (counter == 2) book_value = convert_to_int (line);
if (counter == 3) {
write_value = (line == on ());
setBibleBook (username, bible_value, book_value, write_value);
counter = 0;
}
}
if (loading_features) {
setFeature (username, convert_to_int (line), true);
}
if (line == bibles_start ()) {
loading_bibles = true;
counter = 0;
}
if (line == features_start ()) {
loading_features = true;
counter = 0;
}
}
}
示例2: create
void Database_MorphGnt::create ()
{
filter_url_unlink (database_sqlite_file (filename ()));
SqliteDatabase sql = SqliteDatabase (filename ());
sql.clear ();
sql.add ("CREATE TABLE morphgnt (book int, chapter int, verse int, pos int, parsing int, word int, lemma int);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS pos (pos text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS parsing (parsing text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS word (word text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS lemma (lemma text);");
sql.execute ();
}
示例3: store
void Database_MorphGnt::store (int book, int chapter, int verse,
string pos, string parsing, string word, string lemma)
{
int pos_id = get_id ("pos", pos);
int parsing_id = get_id ("parsing", parsing);
int word_id = get_id ("word", word);
int lemma_id = get_id ("lemma", lemma);
SqliteDatabase sql = SqliteDatabase (filename ());
sql.add ("PRAGMA temp_store = MEMORY;");
sql.execute ();
sql.clear ();
sql.add ("PRAGMA synchronous = OFF;");
sql.execute ();
sql.clear ();
sql.add ("PRAGMA journal_mode = OFF;");
sql.execute ();
sql.clear ();
sql.add ("INSERT INTO morphgnt VALUES (");
sql.add (book);
sql.add (",");
sql.add (chapter);
sql.add (",");
sql.add (verse);
sql.add (",");
sql.add (pos_id);
sql.add (",");
sql.add (parsing_id);
sql.add (",");
sql.add (word_id);
sql.add (",");
sql.add (lemma_id);
sql.add (");");
sql.execute ();
}
示例4: create
void Database_HebrewLexicon::create ()
{
filter_url_unlink (database_sqlite_file (filename ()));
SqliteDatabase sql = SqliteDatabase (filename ());
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS aug (aug text, target text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS bdb (id text, definition text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS map (id text, bdb text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS pos (code text, name text);");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS strong (strong text, definition text);");
sql.execute ();
}
示例5: store
void Database_Kjv::store (int book, int chapter, int verse, string strong, string english)
{
int strongid = get_id ("strong", strong);
int englishid = get_id ("english", english);
SqliteDatabase sql = SqliteDatabase (filename ());
sql.add ("PRAGMA temp_store = MEMORY;");
sql.execute ();
sql.clear ();
sql.add ("PRAGMA synchronous = OFF;");
sql.execute ();
sql.clear ();
sql.add ("PRAGMA journal_mode = OFF;");
sql.execute ();
sql.clear ();
sql.add ("INSERT INTO kjv2 VALUES (");
sql.add (book);
sql.add (",");
sql.add (chapter);
sql.add (",");
sql.add (verse);
sql.add (",");
sql.add (strongid);
sql.add (",");
sql.add (englishid);
sql.add (");");
sql.execute ();
}
示例6: removeUser
// Remove privileges for $username from the entire database.
void Database_Privileges::removeUser (string username)
{
SqliteDatabase sql (database ());
sql.add ("DELETE FROM bibles WHERE username =");
sql.add (username);
sql.add (";");
sql.execute ();
sql.clear ();
sql.add ("DELETE FROM features WHERE username =");
sql.add (username);
sql.add (";");
sql.execute ();
}
示例7: getUsername
// Returns the username that matches the remote IP $address and the browser's user $agent,
// and the other fingerprints from the user.
string Database_Login::getUsername (string address, string agent, string fingerprint)
{
address = md5 (address);
agent = md5 (agent);
fingerprint = md5 (fingerprint);
SqliteDatabase sql (database ());
sql.add ("SELECT rowid, timestamp, username FROM logins WHERE address =");
sql.add (address);
sql.add ("AND agent =");
sql.add (agent);
sql.add ("AND fingerprint =");
sql.add (fingerprint);
sql.add (";");
map <string, vector <string> > result = sql.query ();
if (result.empty()) return "";
string username = result ["username"][0];
int stamp = convert_to_int (result ["timestamp"] [0]);
if (stamp != timestamp ()) {
// Touch the timestamp. This occurs once a day.
int rowid = convert_to_int (result ["rowid"] [0]);
sql.clear ();
sql.add ("UPDATE logins SET timestamp =");
sql.add (timestamp ());
sql.add ("WHERE rowid =");
sql.add (rowid);
sql.execute ();
}
return username;
}
示例8: get_id
int Database_MorphGnt::get_id (const char * table_row, string item)
{
SqliteDatabase sql = SqliteDatabase (filename ());
// Two iterations to be sure a rowid can be returned.
for (unsigned int i = 0; i < 2; i++) {
// Check on the rowid and return it if it's there.
sql.clear ();
sql.add ("SELECT rowid FROM");
sql.add (table_row);
sql.add ("WHERE");
sql.add (table_row);
sql.add ("=");
sql.add (item);
sql.add (";");
vector <string> result = sql.query () ["rowid"];
if (!result.empty ()) return convert_to_int (result [0]);
// The rowid was not found: Insert the word into the table.
// The rowid will now be found during the second iteration.
sql.clear ();
sql.add ("INSERT INTO");
sql.add (table_row);
sql.add ("VALUES (");
sql.add (item);
sql.add (");");
sql.execute ();
}
return 0;
}
示例9: getUsername
// Returns the username that matches the cookie sent by the browser.
// Once a day, $daily will be set true.
string Database_Login::getUsername (string cookie, bool & daily)
{
SqliteDatabase sql (database ());
sql.add ("SELECT rowid, timestamp, username FROM logins WHERE cookie =");
sql.add (cookie);
sql.add (";");
map <string, vector <string> > result = sql.query ();
if (result.empty()) return "";
string username = result ["username"][0];
int stamp = convert_to_int (result ["timestamp"] [0]);
if (stamp != timestamp ()) {
// Touch the timestamp. This occurs once a day.
int rowid = convert_to_int (result ["rowid"] [0]);
sql.clear ();
sql.add ("UPDATE logins SET timestamp =");
sql.add (timestamp ());
sql.add ("WHERE rowid =");
sql.add (rowid);
sql.execute ();
daily = true;
} else {
daily = false;
}
return username;
}
示例10: optimize
void Database_Login::optimize ()
{
if (!healthy ()) {
// (Re)create damaged or non-existing database.
filter_url_unlink (database_sqlite_file (database ()));
create ();
}
// Vacuum it.
SqliteDatabase sql (database ());
// On Android, this pragma prevents the following error: VACUUM; Unable to open database file.
sql.add ("PRAGMA temp_store = MEMORY;");
sql.execute ();
sql.clear ();
sql.add ("VACUUM;");
sql.execute ();
}
示例11: setTokens
// Sets the login security tokens for a user.
// Also store whether the device is touch-enabled.
// It only writes to the table if the combination of username and tokens differs from what the table already contains.
void Database_Login::setTokens (string username, string address, string agent, string fingerprint, string cookie, bool touch)
{
bool daily;
if (username == getUsername (cookie, daily)) return;
address = md5 (address);
agent = md5 (agent);
fingerprint = md5 (fingerprint);
SqliteDatabase sql (database ());
sql.add ("INSERT INTO logins VALUES (");
sql.add (username);
sql.add (",");
sql.add (address);
sql.add (",");
sql.add (agent);
sql.add (",");
sql.add (fingerprint);
sql.add (",");
sql.add (cookie);
sql.add (",");
sql.add (touch);
sql.add (",");
sql.add (timestamp ());
sql.add (");");
sql.execute ();
}
示例12: removeBible
// Remove data for $bible from the database.
void Database_Privileges::removeBible (string bible)
{
SqliteDatabase sql (database ());
sql.add ("DELETE FROM bibles WHERE bible =");
sql.add (bible);
sql.add (";");
sql.execute ();
}
示例13: erase
// Deletes $id from the table.
void Database_Confirm::erase (unsigned int id)
{
SqliteDatabase sql (filename ());
sql.add ("DELETE FROM confirm WHERE id =");
sql.add (id);
sql.add (";");
sql.execute ();
}
示例14: removeTokens
// Remove the login security tokens for a user.
void Database_Login::removeTokens (string username)
{
SqliteDatabase sql (database ());
sql.add ("DELETE FROM logins WHERE username =");
sql.add (username);
sql.add (";");
sql.execute ();
}
示例15: create
void Database_Kjv::create ()
{
SqliteDatabase sql = SqliteDatabase (filename ());
sql.add ("DROP TABLE IF EXISTS kjv2;");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE kjv2 (book int, chapter int, verse int, strong int, english int);");
sql.execute ();
sql.clear ();
sql.add ("DROP TABLE IF EXISTS strong;");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS strong (strong text);");
sql.execute ();
sql.clear ();
sql.add ("DROP TABLE IF EXISTS english;");
sql.execute ();
sql.clear ();
sql.add ("CREATE TABLE IF NOT EXISTS english (english text);");
sql.execute ();
sql.clear ();
sql.add ("VACUUM;");
sql.execute ();
}