• 嵌入式linux sqlite3读写demo


    以下是一个简单的C语言程序,使用SQLite数据库进行读写操作的示例。请确保您已经安装了SQLite3库。

    #include
    #include
    #include <sqlite3.h>

    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”);
    }
    printf(“\n”);
    return 0;
    }

    int main() {
    sqlite3 *db;
    char *zErrMsg = 0;
    int rc;

    rc = sqlite3_open("example.db", &db);
    if (rc) {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return 1;
    }
    
    // 创建一个表
    char *sql = "CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT, email TEXT);";
    rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
    if (rc != SQLITE_OK) {
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }
    
    // 插入数据
    sql = "INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com');";
    rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
    if (rc != SQLITE_OK) {
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }
    
    // 查询数据
    sql = "SELECT * FROM users;";
    rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
    if (rc != SQLITE_OK) {
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }
    
    sqlite3_close(db);
    return 0;
    

    }

    这段代码首先尝试打开一个名为example.db的SQLite数据库。如果数据库不存在,它会创建一个新的数据库。然后,它创建一个名为users的表(如果表不存在的话),接着插入一条记录。最后,它执行一个查询来列出users表中的所有记录。

    确保您有足够的权限来创建和修改example.db文件,并且您的环境中安装了SQLite3库。在编译时,您可能需要链接SQLite3库,使用类似以下的命令行参数:

    gcc -o sqlite_demo sqlite_demo.c -lsqlite3

    运行程序后,您应该在当前目录下看到example.db文件,并且在控制台上看到表的创建和插入操作以及查询结果。

    gcc -o sqlite_demo sqlite_demo.c -lm -lpthread -lstdc++ -lrt -ldl -lresolv -rdynamic -L/path -lsqlite3

  • 相关阅读:
    wifi指纹室内定位系统 计算机竞赛
    压敏电阻有哪些原理?|深圳比创达电子EMC
    进程与线程
    Webpack--动态 import 原理及源码分析
    【HarmonyOS】元服务服务卡片网络开发
    javaweb部署web工程到tomcat中
    Java基础----多线程
    振弦采集仪应用地铁隧道安全监测详细解决方案
    Elasticsearch6.2服务器升配后的bug
    Mac 微信定制化快捷键【截屏、标记、添加文字不再是问题】
  • 原文地址:https://blog.csdn.net/qq_43559669/article/details/140108753