【sqlite3】联系人管理系统

SQLite3实现简单的联系人管理系统

有关sqlite3的基础知识请点击:SQLite3的使用
效果展示:
在这里插入图片描述

创建一个名为contacts.db的数据库

首先,我们需要创建一个名为contacts.db的数据库,并建立一个名为"contact"的表,用于存储联系人信息。该表包含四个列:id、name、phone和email。
以下是创建数据表的SQL语句:

CREATE TABLE IF NOT EXISTS contact (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    name TEXT NOT NULL,
    phone TEXT,
    email TEXT
);

代码:

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

#define DATABASE_NAME "contacts.db"

int main(int argc, char* argv[]) {
	sqlite3 *db;
	char *zErrMsg = 0;
	int rc;
	/*打开数据库*/
	rc = sqlite3_open(DATABASE_NAME, &db);
	if (rc) {
		fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
		sqlite3_close(db);
		return 1;
	} else {
		fprintf(stdout, "Opened database successfully\n");
	}

	/*创建表的SQL语句*/
	char *sql = "CREATE TABLE IF NOT EXISTS contact ("
		"id INTEGER PRIMARY KEY AUTOINCREMENT,"
		"name TEXT NOT NULL,"
		"phone TEXT,"
		"email TEXT"
		");";

	/*执行SQL语句*/
	rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		fprintf(stderr, "SQL error: %s\n", zErrMsg);
		sqlite3_free(zErrMsg);
	} else {
		printf("Table created successfully\n");
	}

	/*关闭数据库文件*/
	sqlite3_close(db);
	return 0;
}

实现“添加联系人”功能的代码:

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

#define DATABASE_NAME "contacts.db"
#define STRLEN 50

int main(int argc, char* argv[]) {
	sqlite3 *db;
	char *zErrMsg = 0;
	int rc;
	/*打开数据库*/
	rc = sqlite3_open(DATABASE_NAME, &db);
	if (rc) {
		fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));
		sqlite3_close(db);
		return 1;
	}

	char *sql_query, name[STRLEN], phone[STRLEN], email[STRLEN];
	int opt;

	/*创建表的SQL语句*/
	char *sql = "CREATE TABLE IF NOT EXISTS contact ("
		"id INTEGER PRIMARY KEY AUTOINCREMENT,"
		"name TEXT NOT NULL,"
		"phone TEXT,"
		"email TEXT"
		");";

	/*执行SQL语句*/
	rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg);
	if (rc != SQLITE_OK) {
		fprintf(stderr, "SQL error: %s\n", zErrMsg);
		sqlite3_free(zErrMsg);
	} else {
		printf("Table created successfully\n");
	}

	while(1) {
		printf("请输入要执行的操作:\n");
		printf("1. 添加联系人\n");
		printf("2. 查找联系人\n");
		printf("3. 更新联系人\n");
		printf("4. 删除联系人\n");
		printf("5. 退出程序\n");
		/*获取用户命令*/
		while( !scanf("%d", &opt) ) getchar();

		switch(opt) {
		case 1:
			// 添加联系人
			printf("请输入姓名:\n");
			scanf("%s", name);
			getchar();
			printf("请输入电话号码:\n");
			scanf("%s", phone);
			getchar();
			printf("请输入电子邮件地址:\n");
			scanf("%s", email);
			getchar();
			printf("您输入的姓名是: %s\t电话号码是: %s\n电子邮件是: %s\n", name, phone, email);
			printf("请输入[y]确认 \n");
			if('y' != getchar()) {
				while(getchar() != '\n');
				printf("添加联系人失败 [已取消]\n");
				continue;
			}
			sql_query = sqlite3_mprintf("INSERT INTO contact "
					"(name, phone, email) VALUES('%s', '%s', '%s')", 
					name, phone, email);
			rc = sqlite3_exec(db, sql_query, NULL, NULL, &zErrMsg);
			if(rc != SQLITE_OK) {
				printf("添加联系人失败 [%s]\n", zErrMsg);
				sqlite3_free(zErrMsg);
			} else {
				printf("添加联系人成功!\n");
			}
			sqlite3_free(sql_query);
			break;	
		case 2:
			//查找联系人
			break;
		case 3:
			//更新联系人
			break;
		case 4:
			//删除联系人
			break;
		case 5:
			sqlite3_close(db);
			return 1;
			break;
		default:
			printf("无效的选项,请重新输入!\n");
			break;
		}
	}
	/*关闭数据库文件*/
	sqlite3_close(db);
	return 0;
}

完整代码

联系人管理系统完整代码

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

#define DATABASE_NAME "contacts.db"
#define STRLEN 50

static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
    int i;
    printf("查询结果:\n");
    for(i = 0; i < argc; i++) {
        printf("%s: %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
    }
    printf("\n");

    return 0;
}

int main(int argc, char* argv[]) {
	sqlite3 *db;
	char *zErrMsg = 0;
	int rc;
	/*打开数据库*/
	rc = sqlite3_open(DATABASE_NAME, &db);
	if (rc) {
		fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));
		sqlite3_close(db);
		return 1;
	}

	char *sql_query, name[STRLEN], phone[STRLEN], email[STRLEN];
	int id, opt;

	/*创建表的SQL语句*/
	char *sql = "CREATE TABLE IF NOT EXISTS contact ("
		"id INTEGER PRIMARY KEY AUTOINCREMENT,"
		"name TEXT NOT NULL,"
		"phone TEXT,"
		"email TEXT"
		");";

	/*执行SQL语句*/
	rc = sqlite3_exec(db, sql, 0, 0, &zErrMsg); // 创建表
	if (rc != SQLITE_OK) {
		fprintf(stderr, "SQL error: %s\n", zErrMsg);
		sqlite3_free(zErrMsg);
	} else {
		printf("Table created successfully\n");
	}

	while(1) {
		printf("请输入要执行的操作:\n");
		printf("1. 添加联系人\n");
		printf("2. 查找联系人\n");
		printf("3. 更新联系人\n");
		printf("4. 删除联系人\n");
		printf("5. 退出程序\n");
		/*获取用户命令*/
		while( !scanf("%d", &opt) ) getchar();

		switch(opt) {
		case 1:
			// 添加联系人
			printf("请输入姓名:\n");
			scanf("%s", name); 
			getchar();
			printf("请输入电话号码:\n");
			scanf("%s", phone);
			getchar();
			printf("请输入电子邮件地址:\n");
			scanf("%s", email);
			getchar();
			printf("您输入的姓名是: %s\t电话号码是: %s\n电子邮件是: %s\n", name, phone, email);
			printf("请输入[y]确认 \n");
			if('y' != getchar()) {
				while(getchar() != '\n');
				printf("添加联系人失败 [已取消]\n");
				continue;
			}
			sql_query = sqlite3_mprintf("INSERT INTO contact "
					"(name, phone, email) VALUES('%s', '%s', '%s')", 
					name, phone, email);
			rc = sqlite3_exec(db, sql_query, NULL, NULL, &zErrMsg);
			if(rc != SQLITE_OK) {
				printf("添加联系人失败 [%s]\n", zErrMsg);
				sqlite3_free(zErrMsg);
			} else {
				printf("添加联系人成功!\n");
			}
			sqlite3_free(sql_query);
			break;	
		case 2:
			//查找联系人
			printf("请输入要查找的姓名或部分姓名:\n");
			scanf("%s", name);
			getchar();

			sql_query = sqlite3_mprintf("SELECT * FROM contact WHERE name LIKE '%s'", name);
			rc = sqlite3_exec(db, sql_query, callback, NULL, &zErrMsg);
			if(rc != SQLITE_OK) {
				printf("查询联系人失败: %s\n", zErrMsg);
				sqlite3_free(zErrMsg);
			}
			break;
		case 3:
			// 更新联系人
			printf("请输入要更新的联系人ID:\n");
			while( !scanf("%d", &id) ) getchar();
			printf("请输入新的姓名:\n");
			scanf("%s", name);
			getchar();
			printf("请输入新的电话号码:\n");
			scanf("%s", phone);
			getchar();
			printf("请输入新的电子邮件地址:\n");
			scanf("%s", email);
			getchar();

			sql_query = sqlite3_mprintf("UPDATE contact SET name='%s', phone='%s', email='%s' WHERE id=%d", 
					name, phone, email, id);
			rc = sqlite3_exec(db, sql_query, NULL, NULL, &zErrMsg);
			if(rc != SQLITE_OK) {
				printf("更新联系人失败: %s\n", zErrMsg);
				sqlite3_free(zErrMsg);
			} else {
				printf("更新联系人成功!\n");
			}
			break;
		case 4:
			// 删除联系人
			printf("请输入要删除的联系人ID:\n");
			while( !scanf("%d", &opt) ) getchar();

			sql_query = sqlite3_mprintf("DELETE FROM contact WHERE id=%d", id); // sqlite3_mprintf函数会自动申请内存空间,
			rc = sqlite3_exec(db, sql_query, NULL, NULL, &zErrMsg);
			if(rc != SQLITE_OK) {
				printf("删除联系人失败: %s\n", zErrMsg);
				sqlite3_free(zErrMsg); // 释放内存空间
			} else {
				printf("删除成功!\n");
			}
			break;
		case 5:
			sqlite3_close(db);
			return 1;
			break;
		default:
			printf("无效的选项,请重新输入!\n");
			break;
		}
	}
	/*关闭数据库文件*/
	sqlite3_close(db);
	return 0;
}

上述代码实现了一个简单的联系人管理系统,可以通过命令行进行添加、查找、更新和删除操作。其中,使用sqlite3_mprintf()函数来创建SQL查询语句。
在程序开始时,会提示用户输入要执行的操作,并根据用户输入的选项来执行相应的操作。每个操作都有相应的提示信息和输入要求,例如添加联系人需要输入姓名、电话号码和电子邮件地址等信息。
在查询联系人时,我们使用回调函数callback()来处理查询结果并将输出内容改为中文。对于其他操作,我们只需检查SQL查询是否成功并处理相应的错误消息即可。
需要注意的是,在实际开发中,还需要对输入进行合法性验证以及防止SQL注入攻击等安全问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/760359.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

某易六月实习笔试

第一题 下面代码需要更改的地方已指出。 解题思路 模拟题&#xff0c;用双指针记录双方当前式神&#xff0c;再记录一下当前谁先手&#xff0c;直到有一方指针越界。 把下面代码now1变为now(now1)%2就行。 第二题 解题思路 01背包变种&#xff0c;只是背包的容量变为多个维度…

打开防火墙设置提示需要使用新应用以打开此windowsdefender

拿到一台新电脑&#xff0c;装好虚拟机。主机ping虚拟机正常&#xff0c;虚拟机上网也正常&#xff0c;但是虚拟机ping主机ping不通。根据我多年虚拟机使用经验&#xff0c;这显然是因为主机防火墙没关。但是当我准备关闭主机防火墙的时候&#xff0c;发现防火墙设置打不开。界…

nvm安装以及idea下vue启动项目过程和注意事项

注意1&#xff1a;nvm版本不要太低&#xff0c;1.1.7会出现下面这个问题&#xff0c;建议1.1.10及其以上版本 然后安装这个教程安装nvm和node.js 链接: nvm安装教程&#xff08;一篇文章所有问题全搞定&#xff0c;非常详细&#xff09; 注意2&#xff1a;上面的教程有一步骤…

【WPF】Windows系统桌面应用程序编程开发新手入门-打造自己的小工具

电脑Windows系统上的桌面程序通常是用Visual Studio 开发工具编写出来的&#xff0c;有两种开发方式供选择&#xff0c;一种是WindowForm&#xff0c;简称WinForm&#xff0c;另一种是Windows Presentation Foundation&#xff0c;简称WPF&#xff0c;这里将学习WPF项目。 文章…

[数据库]mysql用户管理权限管理

目录 ​编辑用户管理​编辑 权限管理 ​编辑 ​编辑 ​编辑案例​编辑 细节 ​编辑 用户管理 我们用创建的用户在登录之后可以看到他和root看到的数据库是完全不一样的 权限管理 案例 登录这个账户可以看到还看不到teatdb这个数据库, 因为还没有授权 分配权限 过来刷新…

MathType2024最新官方无限永久试用版本下载

“我正在使用MathType&#xff0c;它让我的工作变得简单多了。”在中国科学院数学与系统科学研究院的一间办公室内&#xff0c;研究员张益唐兴奋地对《中国科学报》说。 这位因解决了数学界著名的“孪生素数猜想”而名声大噪的数学家&#xff0c;在谈到他最近使用的数学公式编辑…

MM-LLM:CogVLM解读

在图文多模态模型中&#xff0c;范式是图像的编码器、文本编码器、模态融合器。也就是不同模态特征抽取加模态对齐。 这部分可以看李沐的精讲 在大模型里的范式在也是如此&#xff0c;目前的工作大部分都专注于怎么拉齐不同模态。 该论文的动机&#xff08;背景&#xff09;&…

指针类型及数据读取和解释

指针类型的作用和解引用的过程 指针类型的作用&#xff1a; 根据指针类型确定读取数据位数&#xff08;float类型指针&#xff0c;读取32位&#xff09;&#xff1b;根据指针类型解释读取的数据&#xff08;float类型指针&#xff0c;按照1位符号位&#xff0c;8位指数位&…

(单机架设教程)3D剑踪

前言 今天给大家带来一款单机游戏的架设&#xff1a;3D剑踪 如今市面上的资源参差不齐&#xff0c;大部分的都不能运行&#xff0c;本人亲自测试&#xff0c;运行视频如下&#xff1a; 3D剑踪 搭建教程 此游戏架设不需要虚拟机&#xff0c; 我们先解压 “3D剑踪.zip” &…

【计算机图形学 | 基于MFC三维图形开发】期末考试知识点汇总(上)

文章目录 视频教程第一章 计算机图形学概述计算机图形学的定义计算机图形学的应用计算机图形学 vs 图像处理 vs模式识别图形显示器的发展及工作原理理解三维渲染管线 第二章 基本图元的扫描转换扫描转换直线的扫描转换DDA算法Bresenham算法中点画线算法圆的扫描转换中点画圆算法…

老师如何发布期末成绩查询

期末成绩的发布总是让人既期待又紧张。但别担心&#xff0c;今天我就来和大家分享一下如何高效、准确地发布期末成绩查询&#xff0c;让家长和学生都能轻松查到成绩&#xff0c;同时也减轻你的工作负担。 整理成绩数据是关键。确保你的成绩单是最新的&#xff0c;并且已经经过仔…

架构师篇-10、DDD实战篇:通过领域模型落地系统

基于领域模型的设计与开发 数据库设计程序设计微服务设计 在线订餐系统的领域事件通知 微服务拆分 事件风暴会议 梳理领域事件进行领域建模识别聚合关系划分限界上下文 用户下单领域模型 更新后的模型 领域模型的设计实现过程 数据库设计 数据库映射&#xff1a;一对一关系…

【Mac】Auto Mouse Click for Mac(高效、稳定的鼠标连点器软件)软件介绍

软件介绍 Auto Mouse Click for Mac 是一款专为 macOS 平台设计的自动鼠标点击软件&#xff0c;它可以帮助用户自动化重复的鼠标点击操作&#xff0c;从而提高工作效率。以下是这款软件的主要特点和功能&#xff1a; 1.自动化点击操作&#xff1a;Auto Mouse Click 允许用户录…

【硬件视界2】CPU和GPU:计算机架构的双子星

名人说&#xff1a;莫听穿林打叶声&#xff0c;何妨吟啸且徐行。—— 苏轼《定风波莫听穿林打叶声》 本篇笔记整理&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 1、CPU (中央处理器)①主要作用②特点 2、 GPU (图形处理…

Workerman在线客服系统源码,附搭建教程

源码介绍&#xff1a; Workerman在线客服系统源码。 workerman是一个高性能的PHP socket 服务器框架&#xff0c;workerman基于PHP多进程以及libevent事件轮询库&#xff0c;PHP开发者只要实现一两个接口&#xff0c;便可以开发出自己的网络应用&#xff0c;例如Rpc服务、聊天…

气膜仓库的优势与应用—轻空间

随着现代物流和存储需求的不断增长&#xff0c;传统仓库的建设和运营成本日益增加&#xff0c;企业需要寻找更加灵活、高效和经济的解决方案。在这种背景下&#xff0c;气膜仓库作为一种新型仓储形式&#xff0c;以其独特的优势和广泛的应用前景&#xff0c;逐渐受到市场的青睐…

Hadoop3:Yarn配置任务的优先级

一、需求说明 配置队列优先级 容量调度器&#xff0c;支持任务优先级的配置&#xff0c;在资源紧张时&#xff0c;优先级高的任务将优先获取资源。默认情况&#xff0c;Yarn将所有任务的优先级限制为0&#xff0c;若想使用任务的优先级功能&#xff0c;须开放该限制。 二、修…

【STM32嵌入式系统设计与开发---传感器拓展】——1_4_标准库FreeRTOS移植实验

目录 雅俗理解源码下载链接知识拓展步骤1&#xff1a;stm32f103vet6移植freeRTOS步骤:&#xff08;1&#xff09;准备开发环境&#xff08;2&#xff09;添加FreeRTOS移植 致谢 雅俗理解 雅&#xff1a;FreeRTOS是一个开源的实时操作系统&#xff08;RTOS&#xff09;&#xf…

index()方法——字符串首次出现的索引位置

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 语法参考 index()方法用于查询一个字符串在其本身字符串对象中首次出现的索引位置。它与find()方法功能相同&#xff0c;区别在于当find()方法没有检…

数据产品经理知识库构建

概述 数据产品经理是企业中负责管理和推动数据产品的专业人员。他们利用数据来辅助决策&#xff0c;优化产品&#xff0c;提升用户体验。用STAR法则&#xff08;Situation, Task, Action, Result&#xff09;来介绍数据产品经理的角色&#xff0c;应该学习的数据产品&#…