c - 使用 sqlite3 将某些数据分配给结构

标签 c sqlite select struct

我在 C: 中有这个结构

typedef struct{
  char *NOMBRE;
  char *APELLIDO;
  int DNI;
  char *FECHA_NACIMIENTO;
  int TELEFONO;
  char *EMAIL;
  char *DOMICILIO;
  long N_SS ;
  long N_CUENTA ;
  char *PASSWORD;
} Usuario;

现在我已经有了结构,我想通过 SQL 语句将表中的某些数据分配给结构。

这是我的方法:

void bd_sacarDatosUsuario(char *user) {
  sqlite3 *db;
  char *zErrMsg = 0;
  const char* data = "Callback function called";

  char sql[70];
  char sql2[10];
  char user2[10];
  strcpy(sql, "SELECT * FROM DATOS_PERSONALES WHERE DNI='");

  int rc = sqlite3_open("BD/gimud.db", &db);
  if (rc) {
    fprintf(stdout, "Can't open database: %s\n", sqlite3_errmsg(db));
  } else {
    fprintf(stdout, "Opened database successfully\n");
  }
  strcpy(sql2, "';");
  strcpy(user2, user);
  strcat(sql, user2);
  strcat(sql, sql2);

  printf("%s\n", sql);

  rc = sqlite3_exec(db, sql, callback, (void*) data, &zErrMsg);

  if (rc != SQLITE_OK) {
    fprintf(stderr, "SQL error: %s\n", zErrMsg);
    sqlite3_free(zErrMsg);

  } else {
    fprintf(stdout, "Consulta creada con exito\n");
  }
  sqlite3_close(db);
}

如何在回调函数中将数据分配给 Usuario u?我的意思是:

Usuario u;
u.NOMBRE = argv[0]; // and so on...

最佳答案

首先,我想提一下,下面的代码可能不是您正在寻找的最终代码,但它可以帮助您了解回调函数的工作原理。

如果sqlite3_exec()的第三个参数的回调函数不为NULL,则为来自评估的SQL语句的每个结果行调用它。您可以向回调函数传递一个附加参数,在这里您将有机会将表中的数据保存到所谓的 Usuario 结构中。回调的第四个参数用于此目的。

出于演示目的,下面的代码执行以下操作:

  • 打开数据库
  • 创建一个包含三列的表,包括 ID、NAME 和 PASSWORD 字段
  • 在表中插入一行(ID=1、NAME=PETER、PASSWORD=ORANGE)
  • 为结构分配空间
  • 执行 select 语句和存储数据的INVOKES THE CALLBACK()函数。
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
#include <string.h>

typedef struct Usuario{
    char *name;
    char *password;
} Usuario;

int callback(void *Usuario, int argc, char **argv, char **azColName) {
    struct Usuario *tmp = (struct Usuario *)Usuario;
    char missing[] = "MISSING";
    tmp->name = (char *)malloc(sizeof(char) * strlen(argv[1]));
    tmp->name = argv[1] ? argv[1] : (char*)"NULL";
    tmp->password = (char *)malloc(sizeof(char) * strlen(argv[2]));
    tmp->password = argv[2] ? argv[2] : (char*)"NULL";
    return 0;
}


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

    // Open database
    rc = sqlite3_open("test.db", &db);
    if( rc ) {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        return ;
    } else {
        fprintf(stderr, "Opened database successfully\n");
    }

    /* Create table statement */
    const char *sql = "CREATE TABLE TEST("  \
    "ID INT PRIMARY KEY NOT NULL," \
    "NAME CHAR(50) NOT NULL," \
    "PASSWORD CHAR(50) NOT NULL);";
    rc = sqlite3_exec(db, sql, NULL, 0, &zErrMsg);

    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    } else {
        fprintf(stdout, "Success\n");
    }

    // Insert test data
    sql = "INSERT INTO TEST(ID, NAME, PASSWORD) VALUES(1, \"PETER\", \"ORANGE\");";
    rc = sqlite3_exec(db, sql, NULL, 0, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    } else {
        fprintf(stdout, "Success\n");
    }


    // Allocate space for the structure
    struct Usuario *u = (struct Usuario *)malloc(sizeof(struct Usuario));

    sql = "SELECT * FROM TEST";
    rc = sqlite3_exec(db, sql, callback, u, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    } else {
        fprintf(stdout, "Success\n");
    }

    sqlite3_close(db);

    printf("Hi my name is: %s with password of %s\n", u->name, u->password);
}

int main() {
    bd_sacarDatosUsuario();

}

根据您的需要更改结构。请注意,您应该检查 malloc 是否返回非 NULL 值,当然在不需要它后将其释放。

关于c - 使用 sqlite3 将某些数据分配给结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56117066/

相关文章:

C 定义和 char 指针声明之间的错误

java - 读取和插入 Chrome Cookies Java

iPhone (iOS) 应用程序使用本地 sqlite 并希望在多个设备之间同步

MySQL计算非结构化数据的行差异

MySQL如何GROUP BY计数列?

ruby-on-rails - 按字母顺序排列并按首字母分组

C - 使用自定义文件名创建新文件

c - 传递 char 数组但不包含空终止字符

c - C 中的翻转条件检查

python - 跳过 CSV 文件的第一行