C++ 操作sqlite3数据库
2013-09-25 12:37
441 查看
C++ 操作sqlite3数据库
参考:
http://www.cnblogs.com/BoyXiao/archive/2012/03/31/2426495.html
http://blog.csdn.net/harry_lyc/article/details/6663176
http://www.sqlite.org/download.html
http://www.th7.cn/Program/cp/201209/91677.shtml
参考:
http://www.cnblogs.com/BoyXiao/archive/2012/03/31/2426495.html
http://blog.csdn.net/harry_lyc/article/details/6663176
http://www.sqlite.org/download.html
http://www.th7.cn/Program/cp/201209/91677.shtml
#include "stdafx.h" #include "sqlite3.h" #include <iostream> #include <sstream> using namespace std; sqlite3 * pDB; int createTable() { char* errMsg; std::string dropTab = "drop table test_tab;"; string strSQL= "create table test_tab (f1 int, f2 long);"; int res= sqlite3_exec(pDB , dropTab.c_str() , 0 , 0 , &errMsg); if (res != SQLITE_OK) { std::cout << "执行SQL 出错." << errMsg << std::endl; return -1; } res = sqlite3_exec(pDB , strSQL.c_str() ,0 ,0, &errMsg); if (res != SQLITE_OK) { std::cout << "执行创建table的SQL 出错." << errMsg << std::endl; return -1; } else { std::cout << "创建table的SQL成功执行."<< std::endl; } return 0; } int insert1() { char* errMsg; int res = sqlite3_exec(pDB,"begin transaction;",0,0, &errMsg); for (int i= 1; i < 10; ++i) { std::stringstream strsql; strsql << "insert into test_tab values("; strsql << i << ","<< (i+10) << ");"; std::string str = strsql.str(); res = sqlite3_exec(pDB,str.c_str(),0,0, &errMsg); if (res != SQLITE_OK) { std::cout << "执行插入SQL 出错." << errMsg << std::endl; return -1; } } res = sqlite3_exec(pDB,"commit transaction;",0,0, &errMsg); std::cout << "插入SQL成功执行."<< std::endl; return 0; } static int callback(void *NotUsed, int argc, char **argv, char **azColName) { for(int i = 0 ; i < argc ; i++) { std::cout << azColName[i] << " = " << (argv[i] ? argv[i] : "NULL") << ", " ; } std::cout<< "\n"; return 0; } int select1() { char* errMsg; string strSQL= "select * from test_tab;"; int res = sqlite3_exec(pDB, strSQL.c_str(), callback , 0 , &errMsg); if (res != SQLITE_OK) { std::cout << "执行查询SQL 出错." << errMsg << std::endl; return -1; } else { std::cout << "SQL查询成功执行."<< std::endl; } return 0; } int main() { int res = sqlite3_open("D:\\sql.db", &pDB); if( res ){ std::cout << "Can't open database: "<< sqlite3_errmsg(pDB); sqlite3_close(pDB); return -1; } res = createTable(); if (res != 0) { return 0; } res = insert1(); if (res != 0) { return 0; } select1(); return 0; }
相关文章推荐
- 如何在Linux下用C/C++语言操作数据库sqlite3
- 如何在Linux下用C/C++语言操作数据库sqlite3(很不错!设计编译链接等很多问题!)
- C++ 访问操作跨平台数据库Sqlite
- 如何在Linux下用C/C++语言操作数据库sqlite3
- 如何在Linux下用C/C++语言操作数据库sqlite3
- c++ sqlite 操作数据库
- 如何在Linux下用C/C++语言操作数据库sqlite3
- 如何在Linux下用C/C++语言操作数据库sqlite3
- 如何在Linux下用C/C++语言操作数据库sqlite3(很不错!设计编译链接等很多问题!)
- 如何在Linux下用C/C++语言操作数据库sqlite3
- 【Android 开发】:数据存储之 SQLite 数据库操作(一)
- android数据库SQLite操作实例
- sqlite语句,关于使用FMDB操作带有外键的数据库
- Android开发—数据库应用—访问数据表(SQLite OpenHelper) —添加检索操作(Retrieve)
- Sqlite3 c/C++操作入门
- 摘:C++:用ADO操作数据库的方法步骤
- 数据存储之 SQLite 数据库操作(一)
- C++操作数据库写入到json配置文件中
- WINFORM数据库操作,有点像安装里面的SQLITE
- iphone数据库(sqlite3)的用法操作