-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstudent.cpp
180 lines (171 loc) · 4.36 KB
/
student.cpp
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#include </usr/include/mysql/mysql.h>
#include <iostream>
#include <iomanip>//for setw
using namespace std;
void mysql_test(); //进入学生系统
void mysql_insert(); //新增学生信息
void mysql_display(); //查看学生信息
void mysql_delete(); //删除学生信息
void mysql_modify(); //修改学生信息
MYSQL mysql; //创建MySQL变量
MYSQL_RES *res; //包含查询结果集
MYSQL_ROW row; //记录每行数据
int main()
{
while (1)
{
cout << "**********1.进入学生系统**********" << endl;
cout << "**********2.新增学生信息**********" << endl;
cout << "**********3.查看学生信息**********" << endl;
cout << "**********4.删除学生信息**********" << endl;
cout << "**********5.修改学生信息**********" << endl;
cout << "**********6.退出******************" << endl;
int commond;
cout << "请输入命令:";
cin >> commond;
switch (commond)
{
case 1:
{
mysql_test(); break;
}
case 2:
{
mysql_insert(); break;
}
case 3:
{
mysql_display(); break;
}
case 4:
{
mysql_delete(); break;
}
case 5:
{
mysql_modify(); break;
}
case 6:
{
mysql_close(&mysql); return 0;
}
default:
cout << "请输入正确的指令\n";
}
}
return 0;
}
/**********进入学生系统**********/
void mysql_test()
{
mysql_init(&mysql);//初始化并调用MySQL
if (!mysql_real_connect(&mysql, "localhost", "root", "045236", "student", 3306, NULL, 0))
cout << "进入失败,请稍后再试" << endl;
else
cout << "*******欢迎来到管理系统*******" << endl;
}
/**********新增学生信息**********/
void mysql_insert()
{
char sno[40]; //account_number
char name[40]; //account_name
char age[40]; //年龄.
char major[40]; //专业
char sqlstr[1024]; //缓冲
cout << "请依次输入学生学号、姓名、年龄、专业,并用空格隔开:" << endl;
cin >> sno >> name >> age >> major;
int len = sprintf(sqlstr, "INSERT INTO ccc (sno,name,age,major)\
VALUES('%s','%s','%s','%s');",sno,name,age,major);//检查是否有新的输入
mysql_query(&mysql, sqlstr);
if (len < 0)
cout << "新增数据失败\n";
else
cout << "新增数据成功\n";
}
/**********查看学生信息**********/
void mysql_display()
{
mysql_query(&mysql,"select * from ccc");
res = mysql_store_result(&mysql); //获取查询结果
printf("sno\t\tname\tage\tmajor\n");
while ((row = mysql_fetch_row(res))) //读取结果集
{
cout << left << setw(16) << row[0];
cout << left << setw(8) << row[1];
cout << left << setw(8) << row[2];
cout << left << setw(16) << row[3];
cout << endl;
}
mysql_free_result(res); //释放结果集
}
/**********删除学生信息**********/
void mysql_delete()
{
char str[40];
char sqlstr[1024];
cout << "输入要删除的学生学号:";
cin >> str;
int len = sprintf(sqlstr, "delete from ccc where sno=%s", str);
mysql_query(&mysql, sqlstr);//查询
if (len < 0)
cout << "删除数据失败\n";
else
cout << "删除数据成功\n";
}
/**********修改学生信息**********/
void mysql_modify()
{
int commond;
char str[40];
char str1[40];
char sqlstr[1024];
cout << "输入要修改的学生学号:";
cin >> str;
cout << "要修改的内容:1(姓名),2(年龄),3(专业),4(退出):";
cin >> commond;
switch (commond)
{
case 1:
{
cout << "请输入新的姓名:";
cin >> str1;
int len = sprintf(sqlstr,"update ccc set name='%s' where sno=%s", str1, str);
mysql_query(&mysql, sqlstr);
if (len < 0)
cout << "修改数据失败\n";
else
cout << "修改数据成功\n";
break;
}
case 2:
{
cout << "请输入新的年龄:";
cin >> str1;
int len = sprintf(sqlstr, "update ccc set age='%s' where sno=%s", str1, str);
mysql_query(&mysql, sqlstr);
if (len < 0)
cout << "修改数据失败\n";
else
cout << "修改数据成功\n";
break;
}
case 3:
{
cout << "请输入新的专业:";
cin >> str1;
int len = sprintf(sqlstr, "update ccc set major='%s' where sno=%s", str1, str);
mysql_query(&mysql, sqlstr);
if (len < 0)
cout << "修改数据失败\n";
else
cout << "修改数据成功\n";
break;
}
case 4:
{
return;
}
default:
cout << "请输入正确的指令";
}
}