gpt4 book ai didi

c++ - SQLite C++ 插入无符号字符数组

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:14:47 24 4
gpt4 key购买 nike

在阅读了其他几篇文章后,似乎我想要的可能是可能的,但目前我有一组未签名的字符,我希望在 sqlite 中输入我的表的一行。现在我知道 sqlite 使用 UTF-8 编码,所以我认为能够做到这一点,但我不确定。

目前我的代码不起作用我有一张 table ......

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);

关于c++ - SQLite C++ 插入无符号字符数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35209589/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com