SQLite第五课 应用案例

简介:

1 打开数据库文件

  sqlite3* m_db = NULL;

  int ret = sqlite3_open_v2("test.db", &db, SQLITE_OPEN_READWRITE, NULL);

  if (ret != SQLITE_OK)

  {

    return;

  }


2 如果表不存在,创建表

char szCreateUserDataSql[1024] = "create table if not exists tb_user (id INTEGER ,\

    type INTEGER,\

    kind INTEGER)";


3 创建唯一的主键ID

char szCreateUserDataSql[1024] = "create table if not exists tb_user (id INTEGER PRIMARY KEY AUTOINCREMENT,\

    type INTEGER,\

    kind INTEGER)";


4 查询

  char szSql[1024] = {0};

  sprintf(szSql, "select distinct * from tb_test");

  sqlite3_stmt* stmt = NULL;

  sqlite3_prepare(m_db, szSql, -1, &stmt, 0);

  while (sqlite3_step(stmt) == SQLITE_ROW)

  {

    const unsigned char*  szPOIName = sqlite3_column_text(stmt, 0);

    char szName[128] = {0};

    if (szPOIName)

    {

      sprintf(szName, "%s", szPOIName);

    } 

    int kx = sqlite3_column_int(stmt, 3);

    float x = sqlite3_column_double(stmt, 5);

  }

  sqlite3_finalize(stmt);


5 获取sql执行失败的错误信息

char* errMsg = NULL;

char* szSql = "select * from address";

nRet = sqlite3_exec(pDB, szSql, NULL, NULL ,&errMsg);

if (nRet != SQLITE_OK)

{

   cout<<errMsg<<endl;

   sqlite3_free(errMsg);

}

注意:释放errMsg指向的内存

6 关闭数据库

  sqlite3_close(db);







     本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/1956645,如需转载请自行联系原作者
相关文章
|
9月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
775 0
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
859 14
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
1406 15
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
492 8
|
人工智能 小程序 Java
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
本文介绍了一款名为PyWxDump的开源工具,它可以获取微信账户信息、解密SQLite数据库以查看和备份聊天记录。此工具适用于已登录电脑版微信的用户,通过GitHub下载后简单几步即可操作。适合对数据恢复感兴趣的开发者,但请注意合法合规使用并尊重隐私。
3784 2
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
494 4
|
关系型数据库 Java MySQL
C#winform中使用SQLite数据库
C#winform中使用SQLite数据库
1038 3
C#winform中使用SQLite数据库
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
601 3
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
537 2
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
1216 1