0 引言 我们这篇文章主要讲述了如何在C/C++语言中调用 sqlite 的函数接口来实现对数据库的管理, 包括创建数据库、创建表格、插入数据、查询数据、删除数据等。 1 说明 这里我们假设你已经编译好了sqlite的库文件 : libsqlite3a libsqlite3la libsqlite3so libsqlite3so0 libsqlite3so086 pkgconfig 和可执行文件 : sqlite3 我们再假设你的sqlite3的安装目录在 /usr/local/sqlite3 目录下。 如果不是,我们可以这样做,将你的安装文件复制到 /usr/local/sqlite3 这个目录, 这样我们好在下面的 *** 作中更加统一,从而减少出错的概率 例如:[root@localhost home]# cp -rf sqlite-338-ix86/ /usr/local/sqlite3 这里假设 /home/sqlite-338-ix86/ 是你的安装目录,也就是说你的sqlite原来就是安装在这里 这样之后,我们的sqlite3的库文件目录是:/usr/local/sqlite3/lib 可执行文件 sqlite3 的目录是: /usr/local/sqlite3/bin 头文件 sqlite3h 的目录是: /usr/local/sqlite3/include 好拉,现在开始我们的Linux下sqlite3编程之旅。 2 开始 这里我们现在进行一个测试。 现在我们来写个C/C++程序,调用 sqlite 的 API 接口函数。 下面是一个C程序的例子,显示怎么使用 sqlite 的 C/C++ 接口 数据库的名字由第一个参数取得且第二个参数或更多的参数是 SQL 执行语句 这个函数调用sqlite3_open() 在 16 行打开数据库,并且sqlite3_close() 在 25 行关闭数据库连接。 [root@localhost temp]# vi opendbsqlitec 按下i 键切换到输入模式,输入下列代码:// name: opendbsqlitec // This prog is used to test C/C++ API for sqlite3It is very simple,ha! // Author : zieckey All rights reserved // data : 2006/11/13 #include <stdioh> #include <sqlite3h> int main( void ) { sqlite3 db=NULL; char zErrMsg = 0; int rc; //打开指定的数据库文件,如果不存在将创建一个同名的数据库文件 rc = sqlite3_open("zieckeydb", &db); if( rc ) { fprintf(stderr, "Can't open database: %s ", sqlite3_errmsg(db)); sqlite3_close(db); exit(1); } else printf("You have opened a sqlite3 database named zieckeydb successfully! Congratulations! Have fun ! ^-^ "); sqlite3_close(db); //关闭数据库 return 0; } 退出,保存。(代码输入完成后,按下 Esc 键,然后输入: :wq ,回车就好拉) 好拉,现在编译:[root@localhost temp]# gcc opendbsqlitec -o dbout 或者遇到这样的问题:[root@localhost temp]# gcc opendbsqlitec -o dbout opendbsqlitec:11:21: sqlite3h: 没有那个文件或目录 opendbsqlitec: In function `main': opendbsqlitec:19: `sqlite3' undeclared (first use in this function) opendbsqlitec:19: (Each undeclared identifier is reported only once opendbsqlitec:19: for each function it appears in) opendbsqlitec:19: `db' undeclared (first use in this function) 这是由于没有找到头文件的原因。 也许会碰到类似这样的问题:[root@localhost temp]# gcc opendbsqlitec -o dbout /tmp/ccTkItnNo(text+0x2b): In function `main': : undefined reference to `sqlite3_open' /tmp/ccTkItnNo(text+0x45): In function `main': : undefined reference to `sqlite3_errmsg' /tmp/ccTkItnNo(text+0x67): In function `main': : undefined reference to `sqlite3_close' /tmp/ccTkItnNo(text+0x8f): In function `main': : undefined reference to `sqlite3_close' collect2: ld returned 1 exit status 这是个没有找到库文件的问题。 下面我们着手解决这些问题。 由于用到了用户自己的库文件,所用应该指明所用到的库,我们可以这样编译: [root@localhost temp]# gcc opendbsqlitec -o dbout -lsqlite3 我用用 -lsqlite3 选项就可以了(前面我们生成的库文件是 libsqlite3so086 等, 去掉前面的lib和后面的版本标志,就剩下 sqlite3 了所以是 -lsqlite3 )。 如果我们在编译安装的时候,选择了安装路径,例如这样的话: # /sqlite/configure --prefix=/usr/local/sqlite3 # make 作者:zieckey
读取出来的 char 字符么。
atoi 一下 不就变成int了么。
你这个属于存练习 代码 逻辑比较混乱 慢慢来吧
我写过的用 vector 和 map 做的 mysql读取的结果集的封装 你可以看看
>
在C语言中使用ODBC连接数据库时,可以配置多个连接。这是因为一个程序可能需要连接多个数据库,或者一个数据库中可能包含多个不同的数据源。
通过配置多个连接,程序可以同时连接多个数据库或数据源,并对它们进行 *** 作。这样可以提高程序的灵活性和可靠性,同时也可以减少程序的开发时间和维护成本。
在配置多个连接时,需要为每个连接指定不同的DSN(数据源名称),这样程序才能正确地识别和连接到不同的数据库或数据源。同时,还需要为每个连接指定不同的用户名和密码等连接参数,以确保安全性和权限控制。
需要注意的是,配置多个连接可能会增加程序的内存占用和运行时开销,因此需要合理地进行设计和管理。同时,在使用ODBC连接数据库时,还需要注意数据类型的匹配和转换等问题,以避免数据损失或错误。
CDatabase对象表示到数据源的连接,通过它可以 *** 作数据源。数据源是位于一些数据库管理系统(DBMS)的数据的指定实例,包括Server,MicrosoftAess,BorlanddBASE和xBASE。在应用中可以同时使一个或多个CDatabase对象活动。
注意:
如果在处理数据访问对象(DAO)类而不是开放数据库连接(ODBC)类,可使用类。有关的更多信息,请参阅联机文档“VisualC程序员指南”中的“数据库主题(通用)”与“DAO和MFC”。
为使用CDatabase,构造一个CDatabase对象并调用它的OpenEx成员函数。这打开了一个连接。在接着构造CRecordset对象以 *** 纵连接的数据源时,向CDatabase对象传递记录集构造程序指针。完成使用连接时调用Close成员函数并销毁CDatabase对象。Close关闭以前没有关闭的任何记录集。
以上就是关于如何在Linux下用C/C++语言 *** 作数据库sqlite3全部的内容,包括:如何在Linux下用C/C++语言 *** 作数据库sqlite3、c语言调用数据库mysql5.6,数据查询后怎样读取、c语言odbc配置多个连接等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)