• 【网络编程】学习成果day7:用sqlite3和fgetc将字典写入数据库中的数据表。


    1.将字典写入数据库中的数据表
    代码:

    linux@linux:~/study/NETbc$ cat 03_dictsqlite3.c 
    #include
    #define MAX 50
    
    int do_insert(sqlite3* db);
    
    int main(int argc, const char *argv[])
    {
    	//打开数据库
    	sqlite3 *db=NULL;
    	if(sqlite3_open("./dict.db",&db)!=SQLITE_OK)
    	{
    		fprintf(stderr,"sqlite3_open:%s %d __%d__\n",\
    				sqlite3_errmsg(db),sqlite3_errcode(db),__LINE__);
    		return -1;
    	}
    
    	//创建表格
    	char sql[128]="create table if not exists stu (word char,mean char);";
    	char* errmsg=NULL;
    	if(sqlite3_exec(db,sql,NULL,NULL,&errmsg)!=SQLITE_OK)
    	{
    		fprintf(stderr,"sqlite3_exec:%s __%d__\n",errmsg,__LINE__);
    		return -1;
    	}
    	printf("create table stu success\n");
    
    	//调用插入数据函数,创建数据表并将英文字典文本文件的单词和意思导入的数据表中
    	do_insert(db);
    
    	//关闭数据库
    	if(sqlite3_close(db) != SQLITE_OK)
    	{
    		fprintf(stderr,"sqlite3_close:%s %d __%d__\n",\
    				sqlite3_errmsg(db),sqlite3_errcode(db),__LINE__);
    		return -1;
    	}
    	printf("sqlite3_close success\n");
    
    	return 0;
    }
    
    //插入数据
    int do_insert(sqlite3* db)
    {
    	//打开文件操作
    	FILE *fp;
    	fp=fopen("dict.txt","r");
    	char word[MAX]="";
    	char mean[MAX]="";
    	int flag=0; 		//标志位,用来区别记录单词(0)还是意思(1)
    	int a; 				//接受fgetc的返回值,必须用int才能取到EFO,直接用char接收会产生段错误。
    	char ch;   			//记录单个字符
    
    	while((a=fgetc(fp))!=EOF)
    	{
    		ch=a;
    		if(ch=='\n')
    		{
    			//写入数据库操作
    			char sql[128]="";
    			if(snprintf(sql,sizeof(sql),"insert into stu values (\"%s\",\"%s\");",\
    								word,mean) < 0)
    			{
    				fprintf(stderr,"snprintf error:__%d__\n",__LINE__);
    				return -1;
    			}
    
    			char * errmsg=NULL;
    			if(sqlite3_exec(db,sql,NULL,NULL,&errmsg)!=SQLITE_OK)
    			{
    				fprintf(stderr,"sqlite3_exec:%s __%d__\n",errmsg,__LINE__);
    				return -1;
    			}
    			bzero(word,sizeof(word)); 	//给字符串清零
    			bzero(mean,sizeof(mean));
    			flag=0;
    			continue;
    		}else
    		{
    			if(ch==' ') 		//此文件中,当一行中有一个空格时,就开始收集mean字符串
    			{
    				flag=1;
    			}
    			else if(flag==0)
    			{
    				int len=strlen(word);
    				word[len]=ch; 			//把字符加入字符串中
    				word[len+1]='\0'; 		//字符串以'\0'结尾
    			}else
    			{
    				int len=strlen(mean);
    				mean[len]=ch; 			//把字符加入字符串中
    				mean[len+1]='\0'; 		//字符串以'\0'结尾
    			}
    		}
    	}
    
    	return 0;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101

    运行结果:

    linux@linux:~/study/NETbc$ gcc 03_dictsqlite3.c -lsqlite3
    linux@linux:~/study/NETbc$ ./a.out 
    create table stu success
    sqlite3_close success
    linux@linux:~/study/NETbc$ sqlitebrowser dict.db
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    运行结果

  • 相关阅读:
    好用免费的Chat GPT(亲测有用)
    Android11.0(R) MTK 预置可卸载app恢复出厂不恢复(仿RK方案)
    HTML 对象
    读书会丨如何才能不做情绪的人质?
    工作流_工作流平台 JNPF3.3 旗舰版 企业版 开发框架
    SaaSBase:什么是Udesk?
    Eviews用向量自回归模型VAR实证分析公路交通通车里程与经济发展GDP协整关系时间序列数据和脉冲响应可视化...
    华为数通方向HCIP-DataCom H12-831题库(单选题:241-260)
    服务器Debian 12.x中安装Jupyer并配置远程访问
    自注意力(Self-Attention)与Multi-Head Attention机制详解
  • 原文地址:https://blog.csdn.net/kyl_posible/article/details/132679854