2022-07-06 14:06:57 +08:00
|
|
|
/*
|
|
|
|
* 成绩表数据库操作接口实现
|
|
|
|
*/
|
2022-07-03 18:22:02 +08:00
|
|
|
#include"GradeDAO.h"
|
|
|
|
|
|
|
|
void addGrade(_ConnectionPtr connection, Grade grade) {
|
|
|
|
string sql = "insert into grade values('" + grade.getStuId() + "'," +
|
|
|
|
"'" + grade.getCourseId() + "'," +
|
|
|
|
"'" + grade.getGradeStr() + "')";
|
|
|
|
|
|
|
|
connection->Execute(sql.c_str(), NULL, (long)0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void deleteOnesGrade(_ConnectionPtr connection, string stuId, string courseId) {
|
|
|
|
string sql = "delete from grade where stuId = '" + stuId + "\' and courseId = \'" + courseId + "'";
|
|
|
|
|
|
|
|
connection->Execute(sql.c_str(), NULL, (long)0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void deleteGradeByStuId(_ConnectionPtr connection, string stuId) {
|
|
|
|
string sql = "delete from grade where stuId = '" + stuId + "'";
|
|
|
|
|
|
|
|
connection->Execute(sql.c_str(), NULL, (long)0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void deleteGradeByCourseId(_ConnectionPtr connection, string courseId) {
|
|
|
|
string sql = "delete from grade where courseId = '" + courseId + "'";
|
|
|
|
|
|
|
|
connection->Execute(sql.c_str(), NULL, (long)0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void updateOnesGrade(_ConnectionPtr connection, string stuId, string courseId, string grade) {
|
|
|
|
string sql = "update grade set grade = " + grade + " where stuId = '" + stuId + "\' and courseId = \'" + courseId + "'";
|
|
|
|
|
|
|
|
connection->Execute(sql.c_str(), NULL, (long)0);
|
|
|
|
}
|
|
|
|
|
2022-07-04 00:31:52 +08:00
|
|
|
Grade* getOnesGrade(_ConnectionPtr connection, string stuId,string courseId) {
|
2022-07-03 18:22:02 +08:00
|
|
|
string sql = "select * from grade where stuId = '" + stuId + "\' and courseId = \'" + courseId + "'";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-03 18:22:02 +08:00
|
|
|
|
|
|
|
Grade* grade = new Grade();
|
|
|
|
grade->setStuId((char*)(_bstr_t)record->Fields->GetItem("stuId")->Value);
|
|
|
|
grade->setCourseId((char*)(_bstr_t)record->Fields->GetItem("courseId")->Value);
|
|
|
|
grade->setGrade((char*)(_bstr_t)record->Fields->GetItem("grade")->Value);
|
2022-07-04 00:31:52 +08:00
|
|
|
return grade;
|
2022-07-03 18:22:02 +08:00
|
|
|
}
|
|
|
|
|
2022-07-04 00:31:52 +08:00
|
|
|
std::vector<Grade>* getGradeByStuId(_ConnectionPtr connection, string stuId) {
|
2022-07-03 18:22:02 +08:00
|
|
|
string sql = "select * from grade where stuId = '" + stuId + "'";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-03 18:22:02 +08:00
|
|
|
|
|
|
|
std::vector<Grade>* v = new std::vector<Grade>();
|
|
|
|
Grade* grade;
|
|
|
|
for (; !record->EndOfFile; record->MoveNext()) {
|
|
|
|
grade = new Grade();
|
|
|
|
grade->setStuId((char*)(_bstr_t)record->Fields->GetItem("stuId")->Value);
|
|
|
|
grade->setCourseId((char*)(_bstr_t)record->Fields->GetItem("courseId")->Value);
|
|
|
|
grade->setGrade((char*)(_bstr_t)record->Fields->GetItem("grade")->Value);
|
|
|
|
v->push_back(*grade);
|
|
|
|
}
|
2022-07-04 00:31:52 +08:00
|
|
|
return v;
|
2022-07-03 18:22:02 +08:00
|
|
|
}
|
|
|
|
|
2022-07-04 00:31:52 +08:00
|
|
|
std::vector<Grade>* getGradeByCourseId(_ConnectionPtr connection, string courseId) {
|
2022-07-03 18:22:02 +08:00
|
|
|
string sql = "select * from grade where courseId = '" + courseId + "'";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-03 18:22:02 +08:00
|
|
|
|
|
|
|
std::vector<Grade>* v = new std::vector<Grade>();
|
|
|
|
Grade* grade;
|
|
|
|
for (; !record->EndOfFile; record->MoveNext()) {
|
|
|
|
grade = new Grade();
|
|
|
|
grade->setStuId((char*)(_bstr_t)record->Fields->GetItem("stuId")->Value);
|
|
|
|
grade->setCourseId((char*)(_bstr_t)record->Fields->GetItem("courseId")->Value);
|
|
|
|
grade->setGrade((char*)(_bstr_t)record->Fields->GetItem("grade")->Value);
|
|
|
|
v->push_back(*grade);
|
|
|
|
}
|
2022-07-04 00:31:52 +08:00
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<Grade>* getGradeByStuClass(_ConnectionPtr connection, string stuClass) {
|
|
|
|
string sql = "select * from grade where stuId in(select id from student where stuClass = '" + stuClass + "')";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
std::vector<Grade>* v = new std::vector<Grade>();
|
|
|
|
Grade* grade;
|
|
|
|
for (; !record->EndOfFile; record->MoveNext()) {
|
|
|
|
grade = new Grade();
|
|
|
|
grade->setStuId((char*)(_bstr_t)record->Fields->GetItem("stuId")->Value);
|
|
|
|
grade->setCourseId((char*)(_bstr_t)record->Fields->GetItem("courseId")->Value);
|
|
|
|
grade->setGrade((char*)(_bstr_t)record->Fields->GetItem("grade")->Value);
|
|
|
|
v->push_back(*grade);
|
|
|
|
}
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<Grade>* getAllGrade(_ConnectionPtr connection) {
|
|
|
|
string sql = "select * from grade";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
std::vector<Grade>* v = new std::vector<Grade>();
|
|
|
|
Grade* grade;
|
|
|
|
for (; !record->EndOfFile; record->MoveNext()) {
|
|
|
|
grade = new Grade();
|
|
|
|
grade->setStuId((char*)(_bstr_t)record->Fields->GetItem("stuId")->Value);
|
|
|
|
grade->setCourseId((char*)(_bstr_t)record->Fields->GetItem("courseId")->Value);
|
|
|
|
grade->setGrade((char*)(_bstr_t)record->Fields->GetItem("grade")->Value);
|
|
|
|
v->push_back(*grade);
|
|
|
|
}
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
double getOnesAvgGrade(_ConnectionPtr connection, string stuId) {
|
|
|
|
string sql = "select count(*) cnt,sum(grade) all_grade from grade where stuId = '" + stuId + "'";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
int cnt = atoi((char*)(_bstr_t)record->Fields->GetItem("cnt")->Value);
|
|
|
|
double all_grade = atof((char*)(_bstr_t)record->Fields->GetItem("all_grade")->Value);
|
|
|
|
return all_grade / cnt;
|
|
|
|
}
|
|
|
|
|
|
|
|
double getOnesAllGrade(_ConnectionPtr connection, string stuId) {
|
|
|
|
string sql = "select sum(grade) all_grade from grade where stuId = '" + stuId + "'";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
return atof((char*)(_bstr_t)record->Fields->GetItem("all_grade")->Value);
|
|
|
|
}
|
|
|
|
|
|
|
|
double getClassAvgGrade(_ConnectionPtr connection, string stuClass, string courseName) {
|
|
|
|
string sql = "select avg(grade) avg_grade from grade where stuId in (select id from student where stuClass = '" + stuClass + "') ";
|
|
|
|
sql += "and courseId in (select id from course where name = '" + courseName + "')";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
return atof((char*)(_bstr_t)record->Fields->GetItem("avg_grade")->Value);
|
|
|
|
}
|
|
|
|
|
|
|
|
double getClassMaxGrade(_ConnectionPtr connection, string stuClass, string courseName) {
|
|
|
|
string sql = "select max(grade) max_grade from grade where stuId in (select id from student where stuClass = '" + stuClass + "') ";
|
|
|
|
sql += "and courseId in (select id from course where name = '" + courseName + "')";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
return atof((char*)(_bstr_t)record->Fields->GetItem("max_grade")->Value);
|
|
|
|
}
|
|
|
|
|
|
|
|
double getClassMinGrade(_ConnectionPtr connection, string stuClass, string courseName) {
|
|
|
|
string sql = "select min(grade) min_grade from grade where stuId in (select id from student where stuClass = '" + stuClass + "') ";
|
|
|
|
sql += "and courseId in (select id from course where name = '" + courseName + "')";
|
|
|
|
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
2022-07-06 14:06:57 +08:00
|
|
|
if (record->BOF == -1) return NULL;//记录集为空
|
2022-07-04 00:31:52 +08:00
|
|
|
|
|
|
|
return atof((char*)(_bstr_t)record->Fields->GetItem("min_grade")->Value);
|
2022-07-06 14:06:57 +08:00
|
|
|
}
|