• C++之sqlite数据库读写


    C++之sqlite数据库读写

    常用函数

    1、sqlite3_open()
    用于打开SQLite数据库。该函数接受两个参数:数据库文件名和打开模式。成功打开数据库后,将返回一个sqlite3*对象。

    2、sqlite3_close()
    用于关闭SQLite数据库。该函数接受一个sqlite3*对象作为参数。

    3、sqlite3_exec()
    该函数用于执行SQL语句。它接受一个sqlite3*数据库,一个SQL语句字符串和一个回调函数。对于每个从SQL语句返回的记录,回调函数都会被调用。

    4、sqlite3_prepare()
    该函数用于准备要执行的SQL语句。该函数接受一个sqlite3*数据库,一个SQL语句字符串和一个回调函数。当SQL语句准备好执行时,回调函数会被调用。

    5、sqlite3_step()
    该函数用于执行已准备好的SQL语句。该函数接受一个sqlite3*数据库和一个已准备好的SQL语句。对于每个从SQL语句返回的记录,回调函数都会被调用。

    6、sqlite3_finalize()
    该函数用于销毁已准备好的SQL语句。该函数接受一个sqlite3*数据库和一个已准备好的SQL语句。

    7、sqlite3_last_insert_rowid()
    该函数返回最近一次成功的INSERT语句插入的行的ROWID。该函数接受一个sqlite3*数据库作为参数。

    8、sqlite3_changes()
    该函数返回自上次事务以来,被数据库中的UPDATE、INSERT和DELETE语句更改的行数。该函数接受一个sqlite3*数据库作为参数。

    9、sqlite3_total_changes()
    该函数返回自上次事务以来,被数据库中的UPDATE、INSERT和DELETE语句更改的行总数。该函数接受一个sqlite3*数据库作为参数。

    10、sqlite3_interrupt()
    该函数用于中止正在执行的SQLite操作。该函数接受一个sqlite3*数据库作为参数。

    应用例程

    #include   
    #include   
    #include   
      
    static int callback(void* NotUsed, int argc, char** argv, char** azColName) {  
      for(int i = 0; i < argc; i++) {  
        printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");  
      }  
      return 0;  
    }  
      
    int main(int argc, char* argv[]) {  
      sqlite3* db;  
      char* zErrMsg = 0;  
      int rc;  
        
      rc = sqlite3_open("test.db", &db);  
        
      if(rc) {  
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));  
        exit(0);  
      } else {  
        fprintf(stderr, "Opened database successfully\n");  
      }  
        
      char* sql = "CREATE TABLE Friends(Id INT, Name TEXT);";  
        
      rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);  
        
      if(rc != SQLITE_OK) {  
        fprintf(stderr, "SQL error: %s\n", zErrMsg);  
        sqlite3_free(zErrMsg);  
      } else {  
        fprintf(stderr, "Table created successfully\n");  
      }  
        
      sql = "INSERT INTO Friends(Id, Name) VALUES(1, 'Tom');";  
        
      rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);  
        
      if(rc != SQLITE_OK) {  
        fprintf(stderr, "SQL error: %s\n", zErrMsg);  
        sqlite3_free(zErrMsg);  
      } else {  
        fprintf(stderr, "Records inserted successfully\n");  
      }  
        
      sql = "SELECT * FROM Friends;";  
        
      rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);  
        
      if(rc != SQLITE_OK) {  
        fprintf(stderr, "SQL error: %s\n", zErrMsg);  
        sqlite3_free(zErrMsg);        
      } else {  
        fprintf(stderr, "Select operation performed successfully\n");  
      }  
        
      sqlite3_close(db);  
      return 0;  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61

    这个例程演示了如何使用SQLite数据库的C API来执行以下操作:

    打开一个SQLite数据库(如果数据库不存在,则创建一个新数据库)。
    创建一个表格。
    向表格中插入记录。
    查询表格中的记录,并在控制台上显示每条记录的每个字段的值。
    关闭数据库连接。

  • 相关阅读:
    hive修复所有表
    Day37-Http、Maven
    【面试普通人VS高手系列】Spring Boot的约定优于配置,你的理解是什么?
    (二十五)大数据实战——kafka集群及Kafka-Eagle控制台安装与部署
    100天精通Python(可视化篇)——第98天:Pyecharts绘制多种炫酷日历图参数说明+代码实战
    【C++】STL——list模拟实现
    C++内存管理
    互联网快讯:多地要求商家下架槟榔;多所高校延长专硕学制至3年
    webpack自定义loader解析指定后缀名文件
    CPP-Templates-2nd--第十五章 模板实参推导
  • 原文地址:https://blog.csdn.net/techenliu/article/details/133634825