嵌入式中如何用C语言操作sqlite3(07)
在嵌入式系统中使用C语言操作SQLite3数据库,你需要确保SQLite3库已经被集成到你的系统中。以下是一个简单的例子,展示了如何在C语言中使用SQLite3进行基本的数据库操作:
#include <stdio.h>
#include <stdlib.h>
#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;
}
const char *sql = "CREATE TABLE IF NOT EXISTS students (id INTEGER PRIMARY KEY, name TEXT, age INTEGER, address TEXT);";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
const char *sql_insert = "INSERT INTO students (name, age, address) VALUES ('John Doe', 21, '123 Main St');";
rc = sqlite3_exec(db, sql_insert, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
const char *sql_select = "SELECT * FROM students;";
rc = sqlite3_exec(db, sql_select, callback, 0, &zErrMsg);
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sqlite3_close(db);
return 0;
}
确保你的嵌入式系统中已经有了SQLite3库,并且在编译时链接了这个库。上面的代码展示了如何打开数据库、创建表格、插入数据以及查询数据。在实际应用中,你可能需要添加错误处理和其他逻辑以确保程序的健壮性和稳定性。
评论已关闭