• 嵌入式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

  • 相关阅读:
    基于微分段的东西向安全防护,如何提升数据中心运维效率?|社区成长营分享回顾
    【Vue CLI】
    可靠性设计
    Ubuntu MongoDB账户密码设置
    使用Amazon Elasticache构建你的专属内存缓存服务集群
    AMEYA360:村田首款1608M尺寸/100V静电容量1µF的MLCC实现商品化
    macOS - 获取硬件设备信息
    2023江西省大学生信息安全大赛 Crypto
    【自动化测试】——robotframework实战(三)编写测试用例
    mybatis-plus的插件
  • 原文地址:https://blog.csdn.net/qq_43559669/article/details/140108753