目录
一: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");
}
}