添加项目文件。
This commit is contained in:
parent
c114019a8e
commit
a8f69e824b
32
Course.cpp
Normal file
32
Course.cpp
Normal file
@ -0,0 +1,32 @@
|
||||
#ifndef COURSE_CPP
|
||||
#define COURSE_CPP
|
||||
|
||||
#include<string>
|
||||
using std::string;
|
||||
class Course
|
||||
{
|
||||
public:
|
||||
Course() { ; }
|
||||
Course(string id, string name) {
|
||||
this->id = id;
|
||||
this->name = name;
|
||||
}
|
||||
|
||||
string getId() { return id; }
|
||||
void setId(string id) { this->id = id; }
|
||||
string getName() { return name; }
|
||||
void setName(string name) { this->name = name; }
|
||||
|
||||
string toString() {
|
||||
string toStr = "Course{";
|
||||
toStr += "id='" + id + '\'' +
|
||||
", name='" + name + '\'' +
|
||||
'}';
|
||||
return toStr;
|
||||
}
|
||||
private:
|
||||
string id;//¿Î³ÌºÅ
|
||||
string name;//¿Î³ÌÃû
|
||||
};
|
||||
|
||||
#endif // !COURSE_CPP
|
16
CourseDAO.h
Normal file
16
CourseDAO.h
Normal file
@ -0,0 +1,16 @@
|
||||
#ifndef COURSE_DAO_H
|
||||
#define COURSE_DAO_H
|
||||
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include<iostream>
|
||||
#include<vector>
|
||||
#include"Course.cpp"
|
||||
|
||||
void addCourse(_ConnectionPtr connection, Course course);
|
||||
void deleteCourse(_ConnectionPtr connection, string id);
|
||||
void updateCourseName(_ConnectionPtr connection, string id, string name);
|
||||
Course& getCourseById(_ConnectionPtr connection, string id);
|
||||
std::vector<Course>& getCourseByName(_ConnectionPtr connection, string name);
|
||||
|
||||
#endif // !COURSE_DAO_H
|
45
CourseDAOImpl.cpp
Normal file
45
CourseDAOImpl.cpp
Normal file
@ -0,0 +1,45 @@
|
||||
#include"CourseDAO.h"
|
||||
|
||||
void addCourse(_ConnectionPtr connection, Course course) {
|
||||
string sql = "insert into course values('" + course.getId() + "'," +
|
||||
"'" + course.getName() + "')";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
void deleteCourse(_ConnectionPtr connection, string id) {
|
||||
string sql = "delete from course where id = '" + id + "'";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
void updateCourseName(_ConnectionPtr connection, string id, string name) {
|
||||
string sql = "update course set name = '" + name + "\' where id = \'" + id + "'";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
Course& getCourseById(_ConnectionPtr connection, string id) {
|
||||
string sql = "select * from course where id = '" + id + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
Course* course = new Course();
|
||||
course->setId((char*)(_bstr_t)record->Fields->GetItem("id")->Value);
|
||||
course->setName((char*)(_bstr_t)record->Fields->GetItem("name")->Value);
|
||||
return *course;
|
||||
}
|
||||
|
||||
std::vector<Course>& getCourseByName(_ConnectionPtr connection, string name) {
|
||||
string sql = "select * from course where name = '" + name + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
std::vector<Course>* v = new std::vector<Course>();
|
||||
Course* course;
|
||||
for (; !record->EndOfFile; record->MoveNext()) {
|
||||
course = new Course();
|
||||
course->setId((char*)(_bstr_t)record->Fields->GetItem("id")->Value);
|
||||
course->setName((char*)(_bstr_t)record->Fields->GetItem("name")->Value);
|
||||
v->push_back(*course);
|
||||
}
|
||||
return *v;
|
||||
}
|
73
DBCUtils.cpp
Normal file
73
DBCUtils.cpp
Normal file
@ -0,0 +1,73 @@
|
||||
#include"DBCUtils.h"
|
||||
|
||||
bool getConnection(std::string& pwd, _ConnectionPtr& connection) {
|
||||
bool isPwdTrue = false;
|
||||
_bstr_t strConnect;
|
||||
if (!pwd.empty()) {
|
||||
try {
|
||||
std::string con = "Provider=SQLOLEDB.1;Password=" + pwd + "; Persist Security Info = True; User ID = sa; Initial Catalog = stuAdminSystem; Data Source = LAPTOP-4DMOD6O5";
|
||||
strConnect = con.c_str();
|
||||
connection->Open(strConnect, "", "", NULL);
|
||||
isPwdTrue = true;
|
||||
wprintf(L"登录成功!\n");
|
||||
return true;
|
||||
}
|
||||
catch (_com_error& err) {
|
||||
wprintf(L"The application throws the error: %s\n", (wchar_t*)err.ErrorMessage());
|
||||
wprintf(L"Description = %s\n", (wchar_t*)err.Description());
|
||||
}
|
||||
if (!isPwdTrue) {
|
||||
wprintf(L"密码错误!");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else {
|
||||
try {
|
||||
strConnect = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=stuAdminSystem;Data Source=LAPTOP-4DMOD6O5";
|
||||
connection->Open(strConnect, "", "", NULL);
|
||||
isPwdTrue = true;
|
||||
wprintf(L"登录成功!\n");
|
||||
return true;
|
||||
}
|
||||
catch (_com_error& err) {
|
||||
wprintf(L"The application throws the error: %s\n", (wchar_t*)err.ErrorMessage());
|
||||
wprintf(L"Description = %s\n", (wchar_t*)err.Description());
|
||||
}
|
||||
if (!isPwdTrue) {
|
||||
wprintf(L"验证失败!");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void getSqlType(std::string& sql, std::string& comType) {
|
||||
int len = sql.length();
|
||||
for (int i = 0; i < len; i++) {//判断sql语句类型
|
||||
if (sql[i] != ' ')
|
||||
comType += isupper(sql[i]) ? (sql[i] - 32) : sql[i];
|
||||
else return;
|
||||
}
|
||||
}
|
||||
|
||||
void showRecordInfo(_RecordsetPtr& recordSet) {
|
||||
COORD pos = { 0,0 };
|
||||
for (long i = 0; i < recordSet->Fields->Count; i++) {
|
||||
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), pos);
|
||||
wprintf(L"%s", (wchar_t*)recordSet->Fields->GetItem(i)->Name);
|
||||
pos.X += (short)recordSet->Fields->GetItem(i)->DefinedSize % 16 + 4;
|
||||
}
|
||||
for (; !recordSet->EndOfFile; recordSet->MoveNext()) {
|
||||
pos.X = 0;
|
||||
pos.Y++;
|
||||
for (long i = 0; i < recordSet->Fields->Count; i++) {
|
||||
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), pos);
|
||||
if (recordSet->Fields->GetItem(i)->Value.vt == VT_NULL) {
|
||||
wprintf(L"Null");
|
||||
}
|
||||
else {
|
||||
wprintf(L"%s", (wchar_t*)(_bstr_t)recordSet->Fields->GetItem(i)->Value);
|
||||
}
|
||||
pos.X += (short)recordSet->Fields->GetItem(i)->DefinedSize % 16 + 4;
|
||||
}
|
||||
}
|
||||
}
|
15
DBCUtils.h
Normal file
15
DBCUtils.h
Normal file
@ -0,0 +1,15 @@
|
||||
#ifndef DBCUTILS_H
|
||||
#define DBCUTILS_H
|
||||
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include <stdio.h> // wprintf
|
||||
#include <iostream>
|
||||
#include <locale.h> // setlocale
|
||||
#include <string>
|
||||
|
||||
bool getConnection(std::string& pwd, _ConnectionPtr& connection);
|
||||
void getSqlType(std::string& sql, std::string& comType);
|
||||
void showRecordInfo(_RecordsetPtr& recordSet);
|
||||
|
||||
#endif // !DBCUTILS_H
|
38
Grade.cpp
Normal file
38
Grade.cpp
Normal file
@ -0,0 +1,38 @@
|
||||
#ifndef GRADE_CPP
|
||||
#define GRADE_CPP
|
||||
|
||||
#include<string>
|
||||
using std::string;
|
||||
|
||||
class Grade {
|
||||
public:
|
||||
Grade() { ; }
|
||||
Grade(string stuId, string courseId, string grade) {
|
||||
this->stuId = stuId;
|
||||
this->courseId = courseId;
|
||||
this->grade = grade;
|
||||
}
|
||||
|
||||
string getStuId() { return stuId; }
|
||||
void setStuId(string stuId) { this->stuId = stuId; }
|
||||
string getCourseId() { return courseId; }
|
||||
void setCourseId(string courseId) { this->courseId = courseId; }
|
||||
double getGrade() { return atof(grade.c_str()); }
|
||||
string getGradeStr() { return grade; }
|
||||
void setGrade(string grade) { this->grade = grade; }
|
||||
|
||||
string toString() {
|
||||
string toStr = "Grade{";
|
||||
toStr += "stuId='" + stuId + '\'' +
|
||||
", courseId='" + courseId + '\'' +
|
||||
", grade='" + grade + '\'' +
|
||||
'}';
|
||||
return toStr;
|
||||
}
|
||||
private:
|
||||
string stuId;
|
||||
string courseId;
|
||||
string grade;
|
||||
};
|
||||
|
||||
#endif // !GRADE_CPP
|
19
GradeDAO.h
Normal file
19
GradeDAO.h
Normal file
@ -0,0 +1,19 @@
|
||||
#ifndef GRADE_DAO_H
|
||||
#define GRADE_DAO_H
|
||||
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include<iostream>
|
||||
#include<vector>
|
||||
#include"Grade.cpp"
|
||||
|
||||
void addGrade(_ConnectionPtr connection, Grade grade);
|
||||
void deleteOnesGrade(_ConnectionPtr connection, string stuId,string courseId);
|
||||
void deleteGradeByStuId(_ConnectionPtr connection, string stuId);
|
||||
void deleteGradeByCourseId(_ConnectionPtr connection, string courseId);
|
||||
void updateOnesGrade(_ConnectionPtr connection, string stuId, string courseId, string grade);
|
||||
Grade& getOnesGrade(_ConnectionPtr connection, string stuId, string courseId);
|
||||
std::vector<Grade>& getGradeByStuId(_ConnectionPtr connection, string stuId);
|
||||
std::vector<Grade>& getGradeByCourseId(_ConnectionPtr connection, string courseId);
|
||||
|
||||
#endif // !GRADE_DAO_H
|
76
GradeDAOImpl.cpp
Normal file
76
GradeDAOImpl.cpp
Normal file
@ -0,0 +1,76 @@
|
||||
#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);
|
||||
}
|
||||
|
||||
Grade& getOnesGrade(_ConnectionPtr connection, string stuId,string courseId) {
|
||||
string sql = "select * from grade where stuId = '" + stuId + "\' and courseId = \'" + courseId + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
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);
|
||||
return *grade;
|
||||
}
|
||||
|
||||
std::vector<Grade>& getGradeByStuId(_ConnectionPtr connection, string stuId) {
|
||||
string sql = "select * from grade where stuId = '" + stuId + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
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>& getGradeByCourseId(_ConnectionPtr connection, string courseId) {
|
||||
string sql = "select * from grade where courseId = '" + courseId + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
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;
|
||||
}
|
31
SAS.sln
Normal file
31
SAS.sln
Normal file
@ -0,0 +1,31 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 17
|
||||
VisualStudioVersion = 17.2.32616.157
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SAS", "SAS.vcxproj", "{D458779C-7429-43D9-9228-69B41BBC903B}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|x64 = Debug|x64
|
||||
Debug|x86 = Debug|x86
|
||||
Release|x64 = Release|x64
|
||||
Release|x86 = Release|x86
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Debug|x64.ActiveCfg = Debug|x64
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Debug|x64.Build.0 = Debug|x64
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Debug|x86.ActiveCfg = Debug|Win32
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Debug|x86.Build.0 = Debug|Win32
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Release|x64.ActiveCfg = Release|x64
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Release|x64.Build.0 = Release|x64
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Release|x86.ActiveCfg = Release|Win32
|
||||
{D458779C-7429-43D9-9228-69B41BBC903B}.Release|x86.Build.0 = Release|Win32
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {2D725A19-22A9-456E-B8B9-C6AB04B4FED1}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
149
SAS.vcxproj
Normal file
149
SAS.vcxproj
Normal file
@ -0,0 +1,149 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<ItemGroup Label="ProjectConfigurations">
|
||||
<ProjectConfiguration Include="Debug|Win32">
|
||||
<Configuration>Debug</Configuration>
|
||||
<Platform>Win32</Platform>
|
||||
</ProjectConfiguration>
|
||||
<ProjectConfiguration Include="Release|Win32">
|
||||
<Configuration>Release</Configuration>
|
||||
<Platform>Win32</Platform>
|
||||
</ProjectConfiguration>
|
||||
<ProjectConfiguration Include="Debug|x64">
|
||||
<Configuration>Debug</Configuration>
|
||||
<Platform>x64</Platform>
|
||||
</ProjectConfiguration>
|
||||
<ProjectConfiguration Include="Release|x64">
|
||||
<Configuration>Release</Configuration>
|
||||
<Platform>x64</Platform>
|
||||
</ProjectConfiguration>
|
||||
</ItemGroup>
|
||||
<PropertyGroup Label="Globals">
|
||||
<VCProjectVersion>16.0</VCProjectVersion>
|
||||
<Keyword>Win32Proj</Keyword>
|
||||
<ProjectGuid>{d458779c-7429-43d9-9228-69b41bbc903b}</ProjectGuid>
|
||||
<RootNamespace>SAS</RootNamespace>
|
||||
<WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
|
||||
</PropertyGroup>
|
||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
|
||||
<ConfigurationType>Application</ConfigurationType>
|
||||
<UseDebugLibraries>true</UseDebugLibraries>
|
||||
<PlatformToolset>v143</PlatformToolset>
|
||||
<CharacterSet>Unicode</CharacterSet>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
|
||||
<ConfigurationType>Application</ConfigurationType>
|
||||
<UseDebugLibraries>false</UseDebugLibraries>
|
||||
<PlatformToolset>v143</PlatformToolset>
|
||||
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||
<CharacterSet>Unicode</CharacterSet>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
|
||||
<ConfigurationType>Application</ConfigurationType>
|
||||
<UseDebugLibraries>true</UseDebugLibraries>
|
||||
<PlatformToolset>v143</PlatformToolset>
|
||||
<CharacterSet>Unicode</CharacterSet>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
|
||||
<ConfigurationType>Application</ConfigurationType>
|
||||
<UseDebugLibraries>false</UseDebugLibraries>
|
||||
<PlatformToolset>v143</PlatformToolset>
|
||||
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||
<CharacterSet>Unicode</CharacterSet>
|
||||
</PropertyGroup>
|
||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
|
||||
<ImportGroup Label="ExtensionSettings">
|
||||
</ImportGroup>
|
||||
<ImportGroup Label="Shared">
|
||||
</ImportGroup>
|
||||
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||
</ImportGroup>
|
||||
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||
</ImportGroup>
|
||||
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||
</ImportGroup>
|
||||
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||
</ImportGroup>
|
||||
<PropertyGroup Label="UserMacros" />
|
||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||
<ClCompile>
|
||||
<WarningLevel>Level3</WarningLevel>
|
||||
<SDLCheck>true</SDLCheck>
|
||||
<PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||
<ConformanceMode>true</ConformanceMode>
|
||||
</ClCompile>
|
||||
<Link>
|
||||
<SubSystem>Console</SubSystem>
|
||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||
</Link>
|
||||
</ItemDefinitionGroup>
|
||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||
<ClCompile>
|
||||
<WarningLevel>Level3</WarningLevel>
|
||||
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||
<SDLCheck>true</SDLCheck>
|
||||
<PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||
<ConformanceMode>true</ConformanceMode>
|
||||
</ClCompile>
|
||||
<Link>
|
||||
<SubSystem>Console</SubSystem>
|
||||
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||
<OptimizeReferences>true</OptimizeReferences>
|
||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||
</Link>
|
||||
</ItemDefinitionGroup>
|
||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||
<ClCompile>
|
||||
<WarningLevel>Level3</WarningLevel>
|
||||
<SDLCheck>true</SDLCheck>
|
||||
<PreprocessorDefinitions>_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||
<ConformanceMode>true</ConformanceMode>
|
||||
</ClCompile>
|
||||
<Link>
|
||||
<SubSystem>Console</SubSystem>
|
||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||
</Link>
|
||||
</ItemDefinitionGroup>
|
||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||
<ClCompile>
|
||||
<WarningLevel>Level3</WarningLevel>
|
||||
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||
<SDLCheck>true</SDLCheck>
|
||||
<PreprocessorDefinitions>NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||
<ConformanceMode>true</ConformanceMode>
|
||||
</ClCompile>
|
||||
<Link>
|
||||
<SubSystem>Console</SubSystem>
|
||||
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||
<OptimizeReferences>true</OptimizeReferences>
|
||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||
</Link>
|
||||
</ItemDefinitionGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="Course.cpp" />
|
||||
<ClCompile Include="CourseDAOImpl.cpp" />
|
||||
<ClCompile Include="DBCUtils.cpp" />
|
||||
<ClCompile Include="Grade.cpp" />
|
||||
<ClCompile Include="GradeDAOImpl.cpp" />
|
||||
<ClCompile Include="main.cpp" />
|
||||
<ClCompile Include="Student.cpp" />
|
||||
<ClCompile Include="StudentDAOImpl.cpp" />
|
||||
<ClCompile Include="Test.cpp" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClInclude Include="CourseDAO.h" />
|
||||
<ClInclude Include="DBCUtils.h" />
|
||||
<ClInclude Include="GradeDAO.h" />
|
||||
<ClInclude Include="StudentDAO.h" />
|
||||
</ItemGroup>
|
||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||
<ImportGroup Label="ExtensionTargets">
|
||||
</ImportGroup>
|
||||
</Project>
|
60
SAS.vcxproj.filters
Normal file
60
SAS.vcxproj.filters
Normal file
@ -0,0 +1,60 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<ItemGroup>
|
||||
<Filter Include="源文件">
|
||||
<UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
|
||||
<Extensions>cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
|
||||
</Filter>
|
||||
<Filter Include="头文件">
|
||||
<UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
|
||||
<Extensions>h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd</Extensions>
|
||||
</Filter>
|
||||
<Filter Include="资源文件">
|
||||
<UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
|
||||
<Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
|
||||
</Filter>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="main.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="Student.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="Course.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="Grade.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="DBCUtils.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="StudentDAOImpl.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="CourseDAOImpl.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="GradeDAOImpl.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="Test.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClInclude Include="DBCUtils.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="StudentDAO.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="CourseDAO.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="GradeDAO.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
</Project>
|
46
Student.cpp
Normal file
46
Student.cpp
Normal file
@ -0,0 +1,46 @@
|
||||
#ifndef STUDENT_CPP
|
||||
#define STUDENT_CPP
|
||||
|
||||
#include<string>
|
||||
using std::string;
|
||||
|
||||
class Student {
|
||||
public:
|
||||
Student() { ; }
|
||||
Student(string id, string name, string sex, string stuClass, string status) {
|
||||
this->id = id;
|
||||
this->name = name;
|
||||
this->sex = sex;
|
||||
this->stuClass = stuClass;
|
||||
this->status = status;
|
||||
}
|
||||
string getId() { return id; }
|
||||
void setId(string id) { this->id = id; }
|
||||
string getName() { return name; }
|
||||
void setName(string name) { this->name = name; }
|
||||
string getSex() { return sex; }
|
||||
void setSex(string sex) { this->sex = sex; }
|
||||
string getStuClass() { return stuClass; }
|
||||
void setStuClass(string stuClass) { this->stuClass = stuClass; }
|
||||
string getStatus() { return status; }
|
||||
void setStatus(string status) { this->status = status; }
|
||||
|
||||
string toString() {
|
||||
string toStr = "Student{";
|
||||
toStr += "id='" + id + '\'' +
|
||||
", name='" + name + '\'' +
|
||||
", sex='" + sex + '\'' +
|
||||
", stuClass='" + stuClass + '\'' +
|
||||
", status='" + status + '\'' +
|
||||
'}';
|
||||
return toStr;
|
||||
}
|
||||
private:
|
||||
string id;//学号
|
||||
string name;//姓名
|
||||
string sex;//性别
|
||||
string stuClass;//班级
|
||||
string status;//状态(在读、休学、退学)
|
||||
};
|
||||
|
||||
#endif // !STUDENT_CPP
|
17
StudentDAO.h
Normal file
17
StudentDAO.h
Normal file
@ -0,0 +1,17 @@
|
||||
#ifndef STUDENT_DAO_H
|
||||
#define STUDENT_DAO_H
|
||||
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include<iostream>
|
||||
#include<vector>
|
||||
#include"Student.cpp"
|
||||
|
||||
void addStudent(_ConnectionPtr connection, Student student);
|
||||
void deleteStudent(_ConnectionPtr connection, string id);
|
||||
void updateStudentClass(_ConnectionPtr connection, string id, string stuClass);
|
||||
void updateStudentStatus(_ConnectionPtr connection, string id, string status);
|
||||
Student& getStudentById(_ConnectionPtr connection, string id);
|
||||
std::vector<Student>& getStudentByName(_ConnectionPtr connection, string name);
|
||||
|
||||
#endif // !STUDENT_DAO_H
|
60
StudentDAOImpl.cpp
Normal file
60
StudentDAOImpl.cpp
Normal file
@ -0,0 +1,60 @@
|
||||
#include"StudentDAO.h"
|
||||
|
||||
void addStudent(_ConnectionPtr connection, Student student) {
|
||||
string sql = "insert into student values('" + student.getId() + "'," +
|
||||
"'" + student.getName() + "'," +
|
||||
"'" + student.getSex() + "'," +
|
||||
"'" + student.getStuClass() + "'," +
|
||||
"'" + student.getStatus() + "')";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
void deleteStudent(_ConnectionPtr connection, string id) {
|
||||
string sql = "delete from student where id = '" + id + "'";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
void updateStudentClass(_ConnectionPtr connection, string id, string stuClass) {
|
||||
string sql = "update student set stuClass = '" + stuClass + "\' where id = \'" + id + "'";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
void updateStudentStatus(_ConnectionPtr connection, string id, string status) {
|
||||
string sql = "update student set status = '" + status + "\' where id = \'" + id + "'";
|
||||
|
||||
connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
}
|
||||
|
||||
Student& getStudentById(_ConnectionPtr connection, string id) {
|
||||
string sql = "select * from student where id = '" + id + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
Student *student = new Student();
|
||||
student->setId((char*)(_bstr_t)record->Fields->GetItem("id")->Value);
|
||||
student->setName((char*)(_bstr_t)record->Fields->GetItem("name")->Value);
|
||||
student->setSex((char*)(_bstr_t)record->Fields->GetItem("sex")->Value);
|
||||
student->setStuClass((char*)(_bstr_t)record->Fields->GetItem("stuClass")->Value);
|
||||
student->setStatus((char*)(_bstr_t)record->Fields->GetItem("status")->Value);
|
||||
return *student;
|
||||
}
|
||||
|
||||
std::vector<Student>& getStudentByName(_ConnectionPtr connection, string name) {
|
||||
string sql = "select * from student where name = '" + name + "'";
|
||||
_RecordsetPtr record = connection->Execute(sql.c_str(), NULL, (long)0);
|
||||
|
||||
std::vector<Student> *v = new std::vector<Student>();
|
||||
Student* student;
|
||||
for (; !record->EndOfFile; record->MoveNext()) {
|
||||
student = new Student();
|
||||
student->setId((char*)(_bstr_t)record->Fields->GetItem("id")->Value);
|
||||
student->setName((char*)(_bstr_t)record->Fields->GetItem("name")->Value);
|
||||
student->setSex((char*)(_bstr_t)record->Fields->GetItem("sex")->Value);
|
||||
student->setStuClass((char*)(_bstr_t)record->Fields->GetItem("stuClass")->Value);
|
||||
student->setStatus((char*)(_bstr_t)record->Fields->GetItem("status")->Value);
|
||||
v->push_back(*student);
|
||||
}
|
||||
return *v;
|
||||
}
|
100
Test.cpp
Normal file
100
Test.cpp
Normal file
@ -0,0 +1,100 @@
|
||||
/*
|
||||
用于测试DAO功能是否能正常运行
|
||||
*/
|
||||
#if 0
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include <stdio.h> // wprintf
|
||||
#include <iostream>
|
||||
#include <locale.h> // setlocale
|
||||
#include <string>
|
||||
#include<vector>
|
||||
#include "DBCUtils.h"
|
||||
#include "StudentDAO.h"
|
||||
#include "CourseDAO.h"
|
||||
#include "GradeDAO.h"
|
||||
using namespace std;
|
||||
|
||||
int main() {
|
||||
setlocale(LC_ALL, "chs");
|
||||
CoInitializeEx(NULL, COINIT_APARTMENTTHREADED);
|
||||
|
||||
_ConnectionPtr pconnect(_uuidof(Connection));
|
||||
string strConnect = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=stuAdminSystem;Data Source=LAPTOP-4DMOD6O5";
|
||||
pconnect->Open(strConnect.c_str(), "", "", NULL);
|
||||
|
||||
//student
|
||||
/*
|
||||
Student* stu = new Student("2", "李四", "女", "计科00000", "休学");
|
||||
addStudent(pconnect, *stu);
|
||||
deleteStudent(pconnect, "4");
|
||||
updateStudentClass(pconnect, "3", "软件12004");
|
||||
updateStudentStatus(pconnect, "3", "休学");
|
||||
|
||||
Student student = getStudentById(pconnect, "1");
|
||||
cout << student.toString() << "\n";
|
||||
|
||||
vector<Student> v = getStudentByName(pconnect, "张三");
|
||||
for (int i = 0; i < v.size(); i++)
|
||||
cout << v[i].toString() << "\n";
|
||||
*/
|
||||
|
||||
//course
|
||||
/*
|
||||
Course* course1 = new Course("A001","高数");
|
||||
Course* course2 = new Course("A002","C语言");
|
||||
Course* course3 = new Course("A003","体育");
|
||||
addCourse(pconnect, *course1);
|
||||
addCourse(pconnect, *course2);
|
||||
addCourse(pconnect, *course3);
|
||||
|
||||
deleteCourse(pconnect, "A002");
|
||||
updateCourseName(pconnect, "A003", "物理");
|
||||
|
||||
Course cou = getCourseById(pconnect, "A001");
|
||||
cout << cou.toString() << "\n";
|
||||
|
||||
vector<Course> v = getCourseByName(pconnect, "高数");
|
||||
for (int i = 0; i < v.size(); i++)
|
||||
cout << v[i].toString() << "\n";
|
||||
*/
|
||||
|
||||
//grade
|
||||
/*
|
||||
Grade* course1 = new Grade("1","A001","95");
|
||||
Grade* course2 = new Grade("1","A001-1", "95");
|
||||
Grade* course3 = new Grade("1","A003", "95");
|
||||
Grade* course4 = new Grade("2","A001", "95");
|
||||
Grade* course5 = new Grade("2","A003", "95");
|
||||
addGrade(pconnect, *course1);
|
||||
addGrade(pconnect, *course2);
|
||||
addGrade(pconnect, *course3);
|
||||
addGrade(pconnect, *course4);
|
||||
addGrade(pconnect, *course5);
|
||||
|
||||
deleteOnesGrade(pconnect, "1","A001-1");
|
||||
deleteGradeByStuId(pconnect, "1");
|
||||
deleteGradeByCourseId(pconnect, "A001");
|
||||
|
||||
|
||||
updateOnesGrade(pconnect,"1","A001-1","98.4");
|
||||
|
||||
Grade gra = getOnesGrade(pconnect, "1","A001");
|
||||
cout << gra.toString() << "\n";
|
||||
|
||||
cout << "\n";
|
||||
|
||||
vector<Grade> v = getGradeByStuId(pconnect, "1");
|
||||
for (int i = 0; i < v.size(); i++)
|
||||
cout << v[i].toString() << "\n";
|
||||
|
||||
cout << "\n";
|
||||
|
||||
vector<Grade> v1 = getGradeByCourseId(pconnect, "A001");
|
||||
for (int i = 0; i < v1.size(); i++)
|
||||
cout << v1[i].toString() << "\n";
|
||||
*/
|
||||
CoUninitialize();
|
||||
return 0;
|
||||
}
|
||||
#endif
|
34
main.cpp
Normal file
34
main.cpp
Normal file
@ -0,0 +1,34 @@
|
||||
#import "c:\\Program Files\\Common Files\\System\\ado\\msado15.dll" no_namespace rename("EOF", "EndOfFile")
|
||||
|
||||
#include <stdio.h> // wprintf
|
||||
#include <iostream>
|
||||
#include <locale.h> // setlocale
|
||||
#include <string>
|
||||
#include<vector>
|
||||
#include "DBCUtils.h"
|
||||
#include "StudentDAO.h"
|
||||
using namespace std;
|
||||
|
||||
//¸ß¼¶¹¦ÄÜ Ö±½ÓÊäÈësqlÓï¾ä
|
||||
int main() {
|
||||
setlocale(LC_ALL, "chs");
|
||||
CoInitializeEx(NULL, COINIT_APARTMENTTHREADED);
|
||||
|
||||
string pwd;
|
||||
|
||||
wprintf(L"Enter password:");
|
||||
getline(cin, pwd);
|
||||
|
||||
_ConnectionPtr pconnect(_uuidof(Connection));
|
||||
|
||||
if (getConnection(pwd, pconnect)) {
|
||||
try {
|
||||
|
||||
}catch (_com_error& err) {
|
||||
wprintf(L"The application throws the error: %s\n", (wchar_t*)err.ErrorMessage());
|
||||
wprintf(L"Description = %s\n", (wchar_t*)err.Description());
|
||||
}
|
||||
}
|
||||
CoUninitialize();
|
||||
return 0;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user