SQLite--Linux环境下数据库API操作

目录

一:Linux环境下数据库的安装使用

二:API操作创建表(sqlite3_open)

三:API操作数据增/减(sqlite3_exec) 


一:Linux环境下数据库的安装使用

如果Linux下没有安装sqlite3的相关库,安装一下库即可

apt install libsqlite3-dev

创建.c文件

touch mysqlite3.c

查看.c文件是否创建成功

ls

使用vi编辑器 在.c文件中编写程序

vi mysqlite3.c

编译链接

gcc mysqlite3.c -o main

出现错误

尝试解决:查看下虚拟机是否安装sqlite3

whereis sqlite3

尝试解决:虚拟机安装有sqlite, -l 链接一下sqlite3

gcc mysqlite3.c -o main -lsqlite3

 按照自己的想法,并未解决问题

上网查阅资料

 解决问题:安装sqlite3的相关库

apt install libsqlite3-dev

再次编译链接

gcc mysqlite3.c -o main -lsqlite3

运行可执行文件

./main

这里发现自己把\n写成/n导致没有换行[有点小尴尬,不过提醒自己需要细心]

注意:vim xxx.c  [.c文件编写程序,一些小的细节需要细心]

vim mysqlite3

如上,没有写.c 导致进去的时候,代码没了,人傻了

不过编译运行又没问题

后来才发现自己没写.c 【因为不细心,显得自己好憨,哈哈】

二:API操作创建表(sqlite3_open)

数据库是否创建成功

API操作创建表(sqlite3_open)

打印输出hello\n调整回来

不要把 \n换行 和linux命令的 / 搞混了[还是最近贪玩练的太少]

编译链接 

gcc mysqlite3.c -o main -lsqlite3

运行可执行文件 

./main

使用vi编辑器写代码                       vi xxx.c

vi mysqlite3.c

编译运行显示成功success     

ls查看一下成功生成有mydb.db数据库文件

具体实现代码,在下图中展示           cat查看一下

cat mysqlite3.c

vi编写程序

编译

出现报错 分析一下错误原因

vi mysqlite3.c
gcc mysqlite3.c -o main -lsqlite3

报错原因:vi编辑器下不能直接换行,写代码需要\标志来识别换行

vi编写修改程序

编译

运行

vi mysqlite3.c
gcc mysqlite3.c -o main -lsqlite3
./main

结果显示,创建表成功 :

success

Table created successfully

可以去数据库查看一下表是否真的创建出来

ls

打开mydb.db数据库文件 

sqlite3 mydb.db

查看表 

.ta

查看发现user表已经成功创建

检查完毕后,退出数据库

.q

具体代码查看如下图所示                   cat查看

cat mysqlite3.c

三:API操作数据增/减(sqlite3_exec) 

vi编辑器编写.c程序

编译

运行

vi mysqlite3.c
gcc mysqlite3.c -o main -lsqlite3
./main

结果显示 插入数据成功:

success

Table created successfully

insert data successfully

自己验证一下是否成功插入数据          查看ls

ls

打开mydb.db数据库文件 

sqlite3 mydb.db

查看表 

.ta

查看表中数据

select * from user;

可以看到

1001|admin|123456

插入数据成功

检查完毕后,退出数据库

.q

具体代码实现 如下图所示

cat mysqlite3.c

#include "mysqlite.h"

mySqlite::mySqlite(char *mydbname)
{
    char *zErrMsg;
    int ret = sqlite3_open("mydb.db",&mydb);
    if(ret != 0)
    {
        printf("error\n");
    }
    else
    {
        printf("success\n");
    }
}

mySqlite::~mySqlite()
{
    sqlite3_close(mydb);

}

void mySqlite::createUserTable()
{
    char *createsql = "create table if not exists user(userid integer primary key autoincrement,\
       username text not null,\
       userpwd text not null)";
    int rc = sqlite3_exec(mydb,createsql,NULL,0,&zErrMsg);
    if(rc != SQLITE_OK)
    {
        fprintf(stderr,"SQL error:%s\n",zErrMsg);
        sqlite3_free(zErrMsg);
    }
    else
    {
        fprintf(stdout,"Table created successfully\n");
    }
    
    char *insertsql = "insert into user(userid,username,userpwd) values(1001,'admin','123456')";
    rc = sqlite3_exec(mydb,insertsql,NULL,0,&zErrMsg);
    if(rc != SQLITE_OK)
    {
        fprintf(stderr,"SQL error:%s\n",zErrMsg);
        sqlite3_free(zErrMsg);
    }
    else
    {
        fprintf(stdout,"insert data successfully\n");
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chenruhan_QAQ_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值