学生信息管理系统

此程序使用SQLite库编写,编译时需要SQLite3的源码库函数和头文件,编译连接时需加上:-lpthread  -ldl 选项。

(下载地址:http://download.csdn.net/detail/hanbo622/7977201)

      main.c

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "stu_sqlite.h"
#include "sqlite3.h"
#define PRINT printf("    《学生信息管理系统》:");
sqlite3 *db = NULL;
char *help ="*************************************\n"\
			"*add:    add   student  information *\n"\
			"*del:    del   student  information *\n"\
			"*order:  order student  information *\n"\
			"*find:   find  student  information *\n"\
			"*update: find  student  information *\n"\
			"*print:  print student  information *\n"\
			"*cls:    clear  screen  information *\n"\
			"*help:   display  help  information *\n"\
			"*exit:   exit                       *\n"\
			"*************************************\n";
			
void add_fun(void)		
{
	STU stu;
	printf("Please input student (id name city score):");
	scanf("%d %s %s %d",&stu.id,stu.name,stu.city,&stu.score);
	insert_stu_db(db,&stu);
}

void del_fun(void)
{
	STU stu;
	printf("*****************************************************\n");
	printf("*id:    delete     (id=1)       student information *\n");
	printf("*name:  delete (name='hanbo')   student information *\n");
	printf("*city:  delete (city='beijing') student information *\n");
	printf("*score: delete  (score=100)   student information   *\n");
	printf("*****************************************************\n");
	printf("Please input student type:");
	scanf("%s",stu.type);
	delete_stu_db(db, &stu);
}

void order_fun(void)
{
	STU stu;
	printf("***********************************\n");
	printf("*id:    In lin with id order      *\n");
	printf("*name:  In lin with name order    *\n");
	printf("*city:  In lin with city order    *\n");
	printf("*score: In lin with score order   *\n");
	printf("***********************************\n");
	printf("Please input student type:");
	scanf("%s",stu.type);
	order_by_id_stu_db_exec(db,&stu);
}

void find_fun(void)
{
	STU stu;
	printf("****************************************\n");
	printf("*and/or:   id=1 and/or addr='beijing'  *\n");
	printf("*between:  id between 1 and 3          *\n");
	printf("*like:     addr like '%%jing%%'          *\n");
	printf("*not:      id not in (1)               *\n");
	printf("****************************************\n");
	printf("Please input find type:");
	scanf("%s",stu.type);
	find_stu_db(db,&stu);
}
void update_fun(void)
{
	STU stu;
	int i=0;
	printf("**********************************************************\n");
	printf("*      id=1,addr='beijing' where name='perter'           *\n");
	printf("*name peter's information update id=1 and addr='beijing' *\n");
	printf("**********************************************************\n");
	printf("Please input find type:");
	getchar();
	stu.type[i]=getchar();
	while(stu.type[i]!='\n')
	{
		i++;
		stu.type[i]=getchar();
	}
	stu.type[i]='\0';
	
	update_stu_db(db,&stu);
}
void print_fun(void)
{
	show_stu_info(db);
}

void cls_fun(void)
{
	system("clear");
}

void exit_fun(void)
{
	sqlite3_close(db);
	exit(0);
}

void help_fun(void )
{
	printf("%s\n", help);
}

typedef void (*FUN)(void);
typedef struct cmd
{
	char *cmd;
	FUN fun;
}CMD;

CMD cmd_list[] = 
{
	{"add", add_fun},
	{"del", del_fun},
	{"order",order_fun},
	{"find",find_fun},
	{"update",update_fun},
	{"print",print_fun},
	{"cls",cls_fun},
	{"exit",exit_fun},
	{"help",help_fun}
};

int main(int argc, char **argv)
{
	char cmdbuf[20];
	char *stu_db = "stu_info.db";
	int i = 0;

	db = (sqlite3 *)create_db(stu_db); //创建数据库
	create_db_table(db);  //创建表头 id name score
	PRINT;
	while(1)
	{
		scanf("%s",cmdbuf);
		for(i=0;i<9;i++)
		{
			if(!strcmp(cmdbuf,cmd_list[i].cmd))
			{
				cmd_list[i].fun();
				PRINT;
			}
		}
	}
	return 0;
}


stu_sqlite.c

#include <stdio.h>
#include <stdlib.h>

#include "stu_sqlite.h"
#include "sqlite3.h"
void sqlite3_get_table_func(sqlite3 *db,char *sql)
{
	char *errormsg=NULL;
	char **resultp=NULL;
	int nrow=0;
	int ncolumn=0;
	int ret=sqlite3_get_table(db,sql,&resultp,&nrow,&ncolumn,&errormsg);
	if(ret!=SQLITE_OK)
	{
		printf("errormsg=%s\n",errormsg);	
	}
	else
	{
		int i=0;
		int j=0;
		for(i=0;i<=nrow;i++)
		{
			if(i==0)
				printf("  %-3s   %-10s %-10s %-3s  \n",resultp[0],resultp[1],resultp[2],resultp[3]);
			else if(i==1)
			{
				printf("************************************\n");
				printf("* %-3s   %-10s %-10s %-3s  *\n",resultp[0+i*ncolumn],resultp[1+i*ncolumn],resultp[2+i*ncolumn],resultp[3+i*ncolumn]);
			}
			else
				printf("* %-3s   %-10s %-10s %-3s  *\n",resultp[0+i*ncolumn],resultp[1+i*ncolumn],resultp[2+i*ncolumn],resultp[3+i*ncolumn]);		
		}
		printf("************************************\n\n");
	}
}
sqlite3 *create_db(char *db_name)
{
	sqlite3 *db;
	int ret=sqlite3_open(db_name,&db);
	if(ret!=SQLITE_OK)
	{
		perror("sqlite3_open");
	}
	system("chmod 777 stu_info.db");
	return db;
}

void create_db_table(sqlite3 *db)
{
	char *sql="create table persons (id integet,name text,city text,score integet);";
	char *errormsg;
	int ret=sqlite3_exec(db,sql,NULL,NULL,&errormsg);
	if(ret!=SQLITE_OK)
	{
		printf("errormsg=%s\n",errormsg);
	} 
}

void insert_stu_db(sqlite3 *db, STU *stu)
{
	char sql[100]="";
	sprintf(sql,"insert into persons values (%d,'%s','%s',%d);",stu->id,stu->name,stu->city,stu->score);
	char *errormsg;
	int ret=sqlite3_exec(db,sql,NULL,NULL,&errormsg);
	if(ret!=SQLITE_OK)
	{
		printf("errormsg=%s\n",errormsg);
	} 
}

void delete_stu_db(sqlite3 *db, STU *stu)
{
	char sql[100]="";
	char *errormsg;
	sprintf(sql,"delete from persons where %s;",stu->type);
	int ret=sqlite3_exec(db,sql,NULL,NULL,&errormsg);
	if(ret!=SQLITE_OK)
	{
		printf("errormsg=%s\n",errormsg);
	}  
}
void  show_stu_info(sqlite3 *db)
{
	char *sql="select * from persons;";	
	sqlite3_get_table_func(db,sql);
}

void find_stu_db(sqlite3 *db, STU *stu)
{	
	char sql[100]="";
	sprintf(sql,"select * from persons where %s;",stu->type);
	sqlite3_get_table_func(db,sql);
}
void update_stu_db(sqlite3 *db, STU *stu)
{
	char sql[100]="";
	char *errormsg;
	sprintf(sql,"update persons set %s;",stu->type);
	int ret=sqlite3_exec(db,sql,NULL,NULL,&errormsg);
	if(ret!=SQLITE_OK)
	{
		printf("errormsg=%s\n",errormsg);
	}  
}
void order_by_id_stu_db_exec(sqlite3 *db,STU *stu)
{
	char sql[100]="";
	sprintf(sql,"select * from persons order by %s;",stu->type);
	sqlite3_get_table_func(db,sql);
}




stu_sqlite.h

#ifndef __STU_SQLITE_H__
#define __STU_SQLITE_H__

#include "sqlite3.h"

typedef struct student_info
{
	int id;
	char name[10];
	char city[20];
	int score;
	char type[100];
}STU;
extern sqlite3 *create_db(char *db_name);
extern void create_db_table(sqlite3 *db);
extern void insert_stu_db(sqlite3 *db, STU *stu);
extern void delete_stu_db(sqlite3 *db, STU *stu);
extern void order_by_id_stu_db_exec(sqlite3 *db,STU *stu);
extern void find_stu_db(sqlite3 *db, STU *stu);
extern void update_stu_db(sqlite3 *db, STU *stu);
extern void  show_stu_info(sqlite3 *db);

#endif


 

 

你可能感兴趣的:(linux,数据库,sqlite,C语言,ARM)