好的,我终于得到了一个解决方案。遗憾的是我必须回答我自己的问题...
我用SQLite库(http://www.sqlite.org/)。这是一个有点复杂,因为SQLite的文档是有点模糊,但我做了如下:
- 下载sqlitedll * .zip文件 - 提取的.def和地方.dll文件。
- 使用类似于“c:\ program files \ micros〜1 \ vc98 \ bin \ lib”/def:sqlite3.def的命令生成lib文件,从命令 提示符下,在具有DEF文件中,用适当的 路径的LIB.EXE。您可能需要VCVARS32.BAT先运行,这是 也在bin目录中,产生的.LIB复制到适当的 的地方,并设置为一个库目录在VC++。(或者在一个 每个项目的基础上。)
- 下载sqlite-source * .zip文件,并从内部提取sqlite3.h文件 到一个合适的目录。在VC++中包含目录 (同样, )
- 在您的项目中,#include根据需要将sqlite3.lib 添加到您的项目中,将sqlite3.dll复制到您的可执行文件的目录 或工作目录中,并且您应该准备好去。
然后,很容易使用没有出查询,但如果你想使用一个SQL“SELECT”例如,你可以使用此代码:
std::string queries;
// A prepered statement for fetching tables
sqlite3_stmt *stmt;
// Create a handle for database connection, create a pointer to sqlite3
sqlite3 *handle;
// try to create the database. If it doesnt exist, it would be created
// pass a pointer to the pointer to sqlite3, in short sqlite3**
int retval = sqlite3_open("local.db",&handle);
// If connection failed, handle returns NULL
if(retval){
System::Windows::Forms::MessageBox::Show("Database connection failed");
return;
}
// Create the SQL query for creating a table
char create_table[100] = "CREATE TABLE IF NOT EXISTS users (uname TEXT PRIMARY KEY,pass TEXT NOT NULL,activated INTEGER)";
// Execute the query for creating the table
retval = sqlite3_exec(handle,create_table,0,0,0);
// Insert first row and second row
queries = "INSERT INTO users VALUES('manish','manish',1)";
retval = sqlite3_exec(handle,queries.c_str(),0,0,0);
queries = "INSERT INTO users VALUES('mehul','pulsar',0)";
retval = sqlite3_exec(handle,queries.c_str(),0,0,0);
// select those rows from the table
queries = "SELECT * from users";
retval = sqlite3_prepare_v2(handle,queries.c_str(),-1,&stmt,0);
if(retval){
System::Windows::Forms::MessageBox::Show("Selecting data from DB Failed");
return ;
}
// Read the number of rows fetched
int cols = sqlite3_column_count(stmt);
while(1){
// fetch a row’s status
retval = sqlite3_step(stmt);
if(retval == SQLITE_ROW){
// SQLITE_ROW means fetched a row
// sqlite3_column_text returns a const void* , typecast it to const char*
for(int col=0 ; col<cols;col++){
const char *val = (const char*)sqlite3_column_text(stmt,col);
System::Windows::Forms::MessageBox::Show(stdstr2systemstr(sqlite3_column_name(stmt,col))+" = "+stdstr2systemstr(val));
}
}
else
if(retval == SQLITE_DONE){
// All rows finished
System::Windows::Forms::MessageBox::Show("All rows fetched");
break;
}
else{
// Some error encountered
System::Windows::Forms::MessageBox::Show("Some error encountered");
return ;
}
}
// Close the handle to free memory
sqlite3_close(handle);
我希望这个信息有用!
来源:
MSVC曾经有质数据库项目。所有在VS2008附近被移除,几乎没有人在C++中写入dbase代码。并不是很多用户注意到,IDE支持总是缺乏。 –