当前位置: 首页 > news >正文

sqlite3数据库的实现

sqlite3代码实现数据库的插入、删除、修改、退出功能

#include <head.h>
#include <sqlite3.h>
#include <unistd.h>
int do_insert(sqlite3 *db);
int do_delete(sqlite3 *db);
int do_update(sqlite3 *db);int main(int argc, const char *argv[])
{sqlite3 *db = NULL;if(sqlite3_open("./my.db",&db) != SQLITE_OK){fprintf(stdin,"sqlite3_open:%s %d",\sqlite3_errmsg(db),sqlite3_errcode(db));return -1;}printf("sqlite3_open success\n");char sql[128] = "create table if not exists Dictionary (word char,TRANSLATORS char)";char *errmsg = NULL;if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK){fprintf(stderr,"sqlite3_exec:%s %d",errmsg,sqlite3_errcode(db));return -1;}printf("create table Dictionary success\n");char choose = 0;while(1){printf("**********************\n");printf("********1.插入********\n");printf("********2.删除********\n");printf("********3.修改********\n");printf("********4.退出********\n");printf("**********************\n");printf("请输入>>> ");scanf("%s",&choose);getchar();switch(choose){case '1': do_insert(db); break;case '2': do_delete(db); break;case '3': do_update(db); break;case '4': goto END; 	 break;default:printf("输入错误,请重新输入\n");}}END:if(sqlite3_close(db) != SQLITE_OK){fprintf(stdin,"sqlite3_close:%s %d",\sqlite3_errmsg(db),sqlite3_errcode(db));return -1;}return 0;
}
int do_update(sqlite3 *db)
{if(sqlite3_open("./my.db",&db) != SQLITE_OK){fprintf(stdin,"sqlite3_open:%s %d",\sqlite3_errmsg(db),sqlite3_errcode(db));return -1;}char buf[128] = "";char buf_w[128] = "";printf("请输入要修改的单词>>> ");scanf("%s",buf);printf("请输入要修改单词的翻译>>> ");scanf("%s",buf_w);char *errmsg;char sql[128] = "";sprintf(sql,"update Dictionary set TRANSLATORS='%s' where word='%s'",buf,buf_w);if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK){fprintf(stderr,"sqlite3_exec:%s %d\n",errmsg,sqlite3_errcode(db));return -1;}printf("do_update success\n");return 0;
}
int do_insert(sqlite3 *db)
{if(sqlite3_open("./my.db",&db) != SQLITE_OK){fprintf(stdin,"sqlite3_open:%s %d",\sqlite3_errmsg(db),sqlite3_errcode(db));return -1;}char *errmsg;char sql[128] = "";char buf_word[128] = "";char buf_TRAN[128] = "";printf("请输入单词>>> ");scanf("%s",buf_word);printf("请输入翻译>>> ");scanf("%s",buf_TRAN);sprintf(sql,"insert into Dictionary values ('%s','%s')",buf_word,buf_TRAN);if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK){fprintf(stderr,"sqlite3_exec:%s %d\n",errmsg,sqlite3_errcode(db));return -1;}printf("do_insert success\n");return 0;
}
int do_delete(sqlite3 *db)
{if(sqlite3_open("./my.db",&db) != SQLITE_OK){fprintf(stdin,"sqlite3_open:%s %d",\sqlite3_errmsg(db),sqlite3_errcode(db));return -1;}char *errmsg;char buf[128] = "";printf("请输入要删除的单词>>> ");scanf("%s",buf);char sql[128] = "";sprintf(sql,"delete from Dictionary where word='%s'",buf);if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK){fprintf(stderr,"sqlite3_exec:%s %d\n",errmsg,sqlite3_errcode(db));return -1;}printf("do_delete success\n");}
http://www.lryc.cn/news/132687.html

相关文章:

  • c#设计模式-结构型模式 之 桥接模式
  • 【Vue-Router】导航守卫
  • 07无监督学习——降维
  • 系列七、IOC操作bean管理(xml自动装配)
  • 01- vdom 和模板编译源码
  • C++入门知识点——解决C语言不足
  • 探秘分布式大数据:融合专业洞见,燃起趣味火花,启迪玄幻思维
  • 什么是 SPI,和API有什么区别?
  • python3 安装clickhouse_sqlalchemy(greenlet) 失败
  • 五款拿来就能用的炫酷表白代码
  • Springboot 封装整活 Mybatis 动态查询条件SQL自动组装拼接
  • 宝塔部署Java+Vue前后端分离项目经验总结
  • 【公告】停止更新
  • AutoHotKey+VSCode开发扩展推荐
  • 了解 JSON 格式
  • [RDMA] 高性能异步的消息传递和RPC :Accelio
  • typescript报错:‘name‘ was also declared here
  • 第十章:联邦学习视觉案例
  • c语言——输出一个整数的所有因数
  • mqtt学习记录
  • 爬虫逆向实战(十八)--某得科技登录
  • Java-数组
  • Dart 入门Hello world
  • HTML是什么?
  • 【UniApp开发小程序】商品详情展示+评论、评论展示、评论点赞+商品收藏【后端基于若依管理系统开发】
  • rabbitMq安装后无法启动可视化页面http://localhost:15672处理
  • 材料行业可以转IC设计后端吗?
  • vue3 基础知识
  • 【线性代数-3Blue1Brown】- 2 线性组合、张成的空间与基
  • Kafka—工作流程、如何保证消息可靠性