数据库sqlite3操作3(c语言操作数据库)

在这里插入图片描述
sqlite3.h,sqlite3.c在资源中
main.c

#include<stdio.h>
#include"sqlite3.h"

//结果中每一行数据触发一次
int my_fun(void* para,int n_column,char** column_value,char** column_name)
{
    printf("####################\n");
    int i = 0;
    for ( i = 0; i < n_column; i++)
    {
        printf("%s\t",column_name[i]);
    }
    printf("\n");
    return 0;
}
int main(int argc, char const *argv[])
{
    sqlite3* db = NULL;
    int ret = sqlite3_open("stu.db",&db);
    if (ret != SQLITE_OK)
    {
        perror("sqlite3_open");
        return 0;
    }
    
    //操作数据库(增删改查)
    char* sql = "create table persons2(id integer primary key,name text,addr text);";
    sqlite3_exec(db,sql,NULL,NULL,NULL);

    sql = "insert into persons2 values(1,'lucy','bj');";
    sqlite3_exec(db,sql,NULL,NULL,NULL);
     sql = "insert into persons2 values(2,'bobo','sc');";
    sqlite3_exec(db,sql,NULL,NULL,NULL);
     sql = "insert into persons2 values(3,'lili','nj');";
    sqlite3_exec(db,sql,NULL,NULL,NULL);
    //查询
    sql = "select * from persons2;";
    sqlite3_exec(db,sql,my_fun,NULL,NULL);

    char** result = NULL;
    int row=0,col=0;
    sqlite3_get_table(db,sql,&result,&row,&col,NULL);   
    printf("row=%d,col=%d\n",row,col);

//它能看到的就是一维数组
    int i=0,j=0;
    for ( i = 0; i < row; i++)
    {
        for ( j = 0; j < col; j++)
        {
            printf("%s\t",result[i*col+j]);
        }
        printf("\n");
    }
    
    sqlite3_close(db); 
    return 0;
}


在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值