SQLite C++插入无符号字符数组
SQLite C++ inserting unsigned character array
在阅读了其他一些帖子后,似乎我想要的可能是可能的,但目前我有一个无符号字符数组,我希望在 sqlite 中输入到我的表格的一行中。 现在我知道 sqlite 使用 UTF-8 编码,所以我应该认为能够做到这一点,但我不确定。
目前我的代码不起作用,我有一个表格...
void PersonalDataBase::openUserDataBase()
{
int rc;
//table setup
string table = "CREATE TABLE IF NOT EXISTS USERS ("
"_id INTEGER PRIMARY KEY NOT NULL,"
"USERNAME TEXT NOT NULL,"
"PASSWORD TEXT,"
"USERHASH TEXT NOT NULL,"
"EVAL TEXT NOT NULL,"
"NVAL TEXT NOT NULL,"
"PVAL TEXT,"
"QVAL TEXT,"
"DVAL TEXT);";
sqlite3_stmt *stmt;
sqlite3_initialize();
/* Open database */
//Note rc should be checked for errors
rc = sqlite3_open_v2("database/data/UsersDB.db", &userDB, SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE, NULL);
//add table
rc = sqlite3_prepare_v2(userDB, table.c_str(), -1, &stmt, 0);
sqlite3_step(stmt);
sqlite3_finalize(stmt);
}
调用此表后,我的表已创建,但现在插入其中...
现在为了插入到我的表中,我创建一个新条目并生成我的无符号字符数组 e、d、n、p、q,然后......
string insertQuery = "INSERT INTO USERS (USERNAME,PASSWORD,USERHASH,EVAL,NVAL,PVAL,QVAL,DVAL) "
"VALUES ('" + username + "', '" + password + "', ";
//set E
string temp1 = "";
for (int i = 0; i < e -> getLength(); i++)
{
temp1 += (char) e -> getByte(i);
}
insertQuery += temp1 + "', '";
//set N
temp1 = "";
for (int i = 0; i < n -> getLength(); i++)
{
temp1 += (char) n -> getByte(i);
}
insertQuery += temp1 + "', '";
//set P
temp1 = "";
for (int i = 0; i < p -> getLength(); i++)
{
temp1 += (char) p -> getByte(i);
}
insertQuery += temp1 + "', '";
//set Q
temp1 = "";
for (int i = 0; i < q -> getLength(); i++)
{
temp1 += (char) q -> getByte(i);
}
insertQuery += temp1 + "', '";
//set D
temp1 = "";
for (int i = 0; i < d -> getLength(); i++)
{
temp1 += (char) d -> getByte(i);
}
insertQuery += temp1 + "');";
//insert Key + User data into Table
sqlite3_prepare_v2(userDB, insertQuery.c_str(), -1, &stmt1, 0);
sqlite3_step(stmt1);
sqlite3_finalize(stmt1);
我构建了我的查询,但是我很确定我的问题的一部分是我的 getByte(( 函数返回一个无符号字符,这个值可以是任何东西,它的 ascii 等价物可以说 ' 或 ,我认为弄乱我的查询的字符,我的问题是有没有办法直接将我的无符号字符写入我的数据库? 或者我应该创建一个函数,让他们将他们的 8 位转换为 7 位然后工作用字符?但是,这仍然不能解决我的问题,即它可能是'和,或其他字符。有人对我应该在这里做什么有任何想法吗?
若要避免格式问题,请使用参数:
string insertQuery = "INSERT INTO USERS (USERNAME,PASSWORD,USERHASH,EVAL,NVAL,PVAL,QVAL,DVAL) "
"VALUES (?,?,?,?,?,?,?,?);";
err = sqlite3_prepare_v2(userDB, insertQuery.c_str(), -1, &stmt1, 0);
// check err
sqlite3_bind_text(stmt1, 1, username.c_str(), -1, SQLITE_TRANSIENT);
sqlite3_bind_text(stmt1, 2, password.c_str(), -1, SQLITE_TRANSIENT);
sqlite3_bind_text(stmt1, 3, e.c_str(), -1, SQLITE_TRANSIENT);
sqlite3_bind_text(stmt1, 4, n.c_str(), -1, SQLITE_TRANSIENT);
sqlite3_bind_text(stmt1, 5, p.c_str(), -1, SQLITE_TRANSIENT);
sqlite3_bind_text(stmt1, 6, q.c_str(), -1, SQLITE_TRANSIENT);
// or as blob:
sqlite3_bind_blob(stmt1, 7, d.byte_ptr(), d.byte_count(), SQLITE_TRANSIENT);
err = sqlite3_step(stmt1);
相关文章:
- 指向指向字符数组的指针数组的指针
- 比较字符数组
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 使用无符号字符数组有效存储内存
- 错误:字符数组的初始值设定项太多
- 对字符数组中的元素执行逐位操作
- C++ 无法在字符数组中使用 for 循环打印字母模式
- 如何在 C++ 中从文件中读取字符数组(带有一些空格)
- C++ 传递二维字符数组
- 无法在 C++ 中输入字符数组
- 字符数组中的元素数
- 我的目标是编写一个程序来计算和存储字符串在字符数组中出现的位置
- 使用字符数组作为 Map 中的键
- C++:__aligned(__alignof__) 导致字符数组数据出现问题?
- 按顺序声明的字符数组重叠
- 在 C++ 中字符串的大小与字符数组的大小
- 寻找一种更好的方法来表示无符号字符数组
- 如何打印 2D 字符数组C++
- 从字符数组的元素中减去'a'是什么意思
- 我是否不正确地集中了这些字符数组?