系统功能的基本要求(感谢关注!)
1.订户管理:订户增加、修改、删除;
2.目录管理:目录增加、删除、修改;
3.订单管理:完成订户订阅数据的管理;
4.订单查询:按订户查询订单详细情况;
5.统计查询:按报刊目录统计各类报刊的订阅数量及金额。
代码已实现在vc++6.0以及vs2019中成功运行(运行出现问题欢迎私信)
#include <stdlib.h>
#include <windows.h>
#include <sqlucode.h>
#include <iostream>
#include <tchar.h>
using namespace std;
#define CNO_LEN 10
#define NMNO_LEN 10
#define QTY_LEN 4
#define DATE_LEN 10
#define START_LEN 10
#define TERM_LEN 10
#define TITLE_LEN 20
#define PERIOD_LEN 10
#define PRICE_LEN 8
#define NAME_LEN 10
#define ADDR_LEN 20
void back(){}
int main()
{
//定义句柄括和变量
SQLHENV dinghenv; //环境句柄括
SQLHDBC dinghdbc; //连接句柄括
SQLHSTMT dinghstmt; //语句句柄括
SQLRETURN ret;
SQLDOUBLE PRICE;
SQLINTEGER QTY;
SQLCHAR CNO[CNO_LEN], NMNO[NMNO_LEN], DATE1[DATE_LEN], START[START_LEN], TERM[TERM_LEN], TITLE[TITLE_LEN], PERIOD[PERIOD_LEN], NAME[NAME_LEN], ADDR[ADDR_LEN];
SQLINTEGER cbCNO = SQL_NTS, cbNMNO = SQL_NTS, cbQTY = 0, cbDATE1 = SQL_NTS, cbSTART = SQL_NTS, cbTERM = SQL_NTS, cbTITLE = SQL_NTS, cbPERIOD = SQL_NTS, cbNAME = SQL_NTS, cbADDR = SQL_NTS;
SQLINTEGER cbPRICE = 0;
//初始化环境
ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &dinghenv);
ret = SQLSetEnvAttr(dinghenv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, SQL_IS_INTEGER);
//建立连接
ret = SQLAllocHandle(SQL_HANDLE_DBC, dinghenv, &dinghdbc);
ret = SQLConnect(dinghdbc, (SQLCHAR*)(_T("sqlserver")), SQL_NTS, (SQLCHAR*)(_T("sa")), SQL_NTS, (SQLCHAR*)(_T("772739")), SQL_NTS);
if (!(ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO))
{
printf("数据库连接失败!\n");
return -1;
}
else
{
printf("数据库连接成功!加载中.....\n");
Sleep(2000);//延时2秒
system("cls");//清屏
}
loop:
//初始化语句句柄括
ret = SQLAllocHandle(SQL_HANDLE_STMT, dinghdbc, &dinghstmt);
ret = SQLSetStmtAttr(dinghstmt, SQL_ATTR_ROW_BIND_TYPE, (SQLPOINTER)SQL_BIND_BY_COLUMN, SQL_IS_INTEGER);
//执行语句
int x, y, m, n;
cout << "" << endl;
cout << " 订户订阅报刊的应用系统 " << endl;
cout << "" << endl;
cout << " 1、订户管理" << endl;
cout << " 2、目录管理" << endl;
cout << " 3、订单管理" << endl;
cout << " 4、订单查询" << endl;
cout << " 5、统计查询" << endl;
cout << " 6、退出" << endl;
cout << "" << endl;
cout << "请输入您的选择:";
cin >> x;
switch (x)
{
case 1:x = 1;//订户管理
{
system("cls");//清屏
loop1:
cout << "" << endl;
cout << " 订户管理" << endl;
cout << "" << endl;
cout << " 1、增加订户" << endl;
cout << " 2、修改订户" << endl;
cout << " 3、删除订户" << endl;
cout << " 4、返回上级" << endl;
cout << "" << endl;
cout << "请输入您的选择:";
cin >> y;
switch (y)
{
case 1:y = 1; //增加订户
{
SQLCHAR CNO1[CNO_LEN], NAME1[NAME_LEN], ADDR1[ADDR_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("INSERT INTO CUSTOMER(CNO,NAME,ADDR) VALUES(?,?,?)")), SQL_NTS);
cout << "输入订户信息(订户编号,姓名,地址):" << endl;
cin >> CNO1;
cin >> NAME1;
cin >> ADDR1;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbNAME = SQL_NTS; cbADDR = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO1, 0, &cbCNO);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NAME_LEN, 0, NAME1, 0, &cbNAME);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, ADDR_LEN, 0, ADDR1, 0, &cbADDR);
}
cout << "添加订户成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);//Step 6 处理结果集并执行预编译后的语句
}
goto loop1;
case 2:y = 2;//修改订户
{
SQLCHAR CNO2[CNO_LEN], NAME2[NAME_LEN], ADDR2[ADDR_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("UPDATE CUSTOMER SET NAME=?, ADDR=? WHERE CNO=?")), SQL_NTS);
cout << "输入订户编号以及修改信息(姓名,地址):" << endl;
cin >> CNO2;
cin >> NAME2;
cin >> ADDR2;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbNAME = SQL_NTS; cbADDR = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NAME_LEN, 0, NAME2, 0, &cbNAME);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, ADDR_LEN, 0, ADDR2, 0, &cbADDR);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO2, 0, &cbCNO);
}
cout << "修改订户信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop1;
case 3:y = 3;//删除订户
{
SQLCHAR CNO3[CNO_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("DELETE FROM CUSTOMER WHERE CNO=?")), SQL_NTS);
cout << "输入要删除的订户编号" << endl;
cin >> CNO3;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO3, 0, &cbCNO);
}
cout << "删除订户成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop1;
case 4:y = 4;
system("cls");//清屏
goto loop;
}
}
case 2:x = 2;//报刊目录管理
{
system("cls");//清屏
loop2:
cout << "" << endl;
cout << " 报刊目录管理" << endl;
cout << "" << endl;
cout << " 1、增加报刊目录" << endl;
cout << " 2、修改报刊目录" << endl;
cout << " 3、删除报刊目录" << endl;
cout << " 4、返回上级" << endl;
cout << "" << endl;
cout << "请输入您的选择:";
cin >> m;
switch (m)
{
case 1:y = 1;//增加报刊目录
{
SQLCHAR NMNO1[NMNO_LEN], TITLE1[TITLE_LEN], PERIOD1[PERIOD_LEN];
SQLDOUBLE PRICE1;
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("INSERT INTO NMTABLE(NMNO,TITLE,PERIOD,PRICE) VALUES(?,?,?,?)")), SQL_NTS);
cout << "输入报刊信息(报刊号,名称,刊期,单价):" << endl;
cin >> NMNO1;
cin >> TITLE1;
cin >> PERIOD1;
cin >> PRICE1;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbNMNO = SQL_NTS; cbTITLE = SQL_NTS; cbPERIOD = SQL_NTS; cbPRICE = 0;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO1, 0, &cbNMNO);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, TITLE_LEN, 0, TITLE1, 0, &cbTITLE);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, PERIOD_LEN, 0, PERIOD1, 0, &cbPERIOD);
ret = SQLBindParameter(dinghstmt, 4, SQL_PARAM_INPUT, SQL_C_DOUBLE, SQL_DOUBLE, 0, 0, &PRICE1, 0, &cbPRICE);
}
cout << "录入报刊信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop2;
case 2:y = 2;//修改报刊目录
{
SQLCHAR NMNO2[NMNO_LEN], TITLE2[TITLE_LEN], PERIOD2[PERIOD_LEN];
SQLDOUBLE PRICE2;
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("UPDATE NMTABLE SET TITLE=?,PERIOD=?,PRICE=? WHERE NMNO=?")), SQL_NTS);
cout << "输入报刊号及修改信息(名称,刊期,单价):" << endl;
cin >> NMNO2;
cin >> TITLE2;
cin >> PERIOD2;
cin >> PRICE2;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbNMNO = SQL_NTS; cbTITLE = SQL_NTS; cbPERIOD = SQL_NTS; cbPRICE = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, TITLE_LEN, 0, TITLE2, 0, &cbTITLE);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, PERIOD_LEN, 0, PERIOD2, 0, &cbPERIOD);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_DOUBLE, SQL_DOUBLE, 0, 0, &PRICE2, 0, &cbPRICE);
ret = SQLBindParameter(dinghstmt, 4, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO2, 0, &cbNMNO);
}
cout << "修改报刊信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop2;
case 3:m = 3;//删除报刊目录
{
SQLCHAR NMNO3[NMNO_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("DELETE FROM NMTABLE WHERE NMNO=?")), SQL_NTS);
cout << "输入要删除的报刊号" << endl;
cin >> NMNO3;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO3, 0, &cbNMNO);
}
cout << "删除报刊信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop2;
case 4:m = 4;
system("cls");//清屏
goto loop;
}
}
case 3:x = 3;//订单管理
{
system("cls");//清屏
loop3:
cout << "" << endl;
cout << " 订单管理" << endl;
cout << "" << endl;
cout << " 1、增加订单" << endl;
cout << " 2、修改订单" << endl;
cout << " 3、删除订单" << endl;
cout << " 4、返回上级" << endl;
cout << "" << endl;
cout << "请输入您的选择:";
cin >> n;
switch (n)
{
case 1:m = 1; //增加订单
{
SQLCHAR CNO4[CNO_LEN], DATE4[DATE_LEN], NMNO4[NMNO_LEN], START4[START_LEN], TERM4[TERM_LEN];
SQLINTEGER QTY4;
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("INSERT INTO [dbo].[ORDER](CNO,DATE1,NMNO,START,TERM,QTY) VALUES(?,?,?,?,?,?)")), SQL_NTS);
cout << "输入订单信息(订户编号,日期,报刊号,起订期,终订期,份数):" << endl;
cin >> CNO4;
cin >> DATE4;
cin >> NMNO4;
cin >> START4;
cin >> TERM4;
cin >> QTY4;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbDATE1 = SQL_NTS; cbNMNO = SQL_NTS; cbSTART = SQL_NTS; cbTERM = SQL_NTS; cbQTY = 0;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO4, 0, &cbCNO);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, DATE_LEN, 0, DATE4, 0, &cbDATE1);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO4, 0, &cbNMNO);
ret = SQLBindParameter(dinghstmt, 4, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, START_LEN, 0, START4, 0, &cbSTART);
ret = SQLBindParameter(dinghstmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, TERM_LEN, 0, TERM4, 0, &cbTERM);
ret = SQLBindParameter(dinghstmt, 6, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &QTY4, 0, &cbQTY);
}
cout << "添加订单信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop3;
case 2:n = 2;//修改订单
{
SQLCHAR CNO5[CNO_LEN], DATE5[DATE_LEN], NMNO5[NMNO_LEN], START5[START_LEN], TERM5[TERM_LEN];
SQLINTEGER QTY5;
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("UPDATE [dbo].[ORDER] SET DATE1=?,START=?,TERM=?,QTY=? WHERE CNO=? AND NMNO=?")), SQL_NTS);
cout << "输入订单订户编号和报刊号及修改信息(日期,起订期,终订期,份数)" << endl;
cin >> CNO5;
cin >> NMNO5;
cin >> DATE5;
cin >> START5;
cin >> TERM5;
cin >> QTY5;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbDATE1 = SQL_NTS; cbNMNO = SQL_NTS; cbSTART = SQL_NTS; cbTERM = SQL_NTS; cbQTY = 0;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, DATE_LEN, 0, DATE5, 0, &cbDATE1);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, START_LEN, 0, START5, 0, &cbSTART);
ret = SQLBindParameter(dinghstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, TERM_LEN, 0, TERM5, 0, &cbTERM);
ret = SQLBindParameter(dinghstmt, 4, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &QTY5, 0, &cbQTY);
ret = SQLBindParameter(dinghstmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO5, 0, &cbCNO);
ret = SQLBindParameter(dinghstmt, 6, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO5, 0, &cbNMNO);
}
cout << "修改订单信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop3;
case 3:n = 3;//删除订单
{
SQLCHAR CNO6[CNO_LEN], NMNO6[NMNO_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("DELETE FROM [dbo].[ORDER] WHERE CNO=? AND NMNO=?")), SQL_NTS);
cout << "输入要删除订单的用户号与报刊号:" << endl;
cin >> CNO6;
cin >> NMNO6;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbNMNO = SQL_NTS;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO6, 0, &cbCNO);
ret = SQLBindParameter(dinghstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NMNO_LEN, 0, NMNO6, 0, &cbNMNO);
}
cout << "删除订单信息成功!" << endl;
system("pause");//冻结屏幕
system("cls");//清屏
ret = SQLExecute(dinghstmt);
}
goto loop3;
case 4:n = 4;
system("cls");//清屏
goto loop;
}
}
case 4:x = 4;//查询订单
{
SQLCHAR CNO7[CNO_LEN], DATE7[DATE_LEN], NMNO7[NMNO_LEN], START7[START_LEN], TERM7[TERM_LEN];
SQLINTEGER QTY7;
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("SELECT * FROM [dbo].[ORDER] WHERE CNO=?")), SQL_NTS);
cout << "输入查询的订户编号:";
cin >> CNO7;
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbCNO = SQL_NTS; cbDATE1 = SQL_NTS; cbNMNO = SQL_NTS; cbSTART = SQL_NTS; cbTERM = SQL_NTS; cbQTY = 0;
ret = SQLBindParameter(dinghstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, CNO_LEN, 0, CNO7, 0, &cbCNO);
ret = SQLBindCol(dinghstmt, 1, SQL_C_CHAR, CNO7, CNO_LEN, &cbCNO);
ret = SQLBindCol(dinghstmt, 2, SQL_C_CHAR, DATE7, DATE_LEN, &cbDATE1);
ret = SQLBindCol(dinghstmt, 3, SQL_C_CHAR, NMNO7, NMNO_LEN, &cbNMNO);
ret = SQLBindCol(dinghstmt, 4, SQL_C_CHAR, START7, START_LEN, &cbSTART);
ret = SQLBindCol(dinghstmt, 5, SQL_C_CHAR, TERM7, TERM_LEN, &cbTERM);
ret = SQLBindCol(dinghstmt, 6, SQL_C_LONG, &QTY7, 0, &cbQTY);
}
cout << "订户编号 日期 报刊号 起订期 终订期 份数" << endl;
ret = SQLExecute(dinghstmt);
while (SQLFetch(dinghstmt) != SQL_NO_DATA_FOUND)
{
cout << CNO7 << DATE7 << NMNO7 << START7 << TERM7 << QTY7 << endl;
}
system("pause");//冻结屏幕
system("cls");//清屏
goto loop;
}
case 5:x = 5;//统计查询
{
SQLINTEGER SUM1;
SQLDOUBLE SUM2;
SQLINTEGER cbSUM1;
SQLINTEGER cbSUM2;
SQLCHAR NMNO[NMNO_LEN];
ret = SQLPrepare(dinghstmt, (SQLCHAR*)(_T("SELECT [dbo].[ORDER].NMNO,SUM(QTY),SUM(QTY*PRICE) FROM [dbo].[ORDER],NMTABLE WHERE [dbo].[ORDER].NMNO=NMTABLE.NMNO GROUP BY [dbo].[ORDER].NMNO")), SQL_NTS);
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
cbNMNO = SQL_NTS; cbSUM1 = 0; cbSUM2 = 0;
ret = SQLBindCol(dinghstmt, 1, SQL_C_CHAR, NMNO, NMNO_LEN, &cbNMNO);
ret = SQLBindCol(dinghstmt, 2, SQL_C_LONG, &SUM1, 0, &cbSUM1);
ret = SQLBindCol(dinghstmt, 3, SQL_C_DOUBLE, &SUM2, 0, &cbSUM2);
}
cout << "报刊号 份数 总价"<<endl;
ret = SQLExecute(dinghstmt);
while (SQLFetch(dinghstmt) != SQL_NO_DATA_FOUND)
{
cout << NMNO << SUM1 << " " << SUM2 << endl;
}
system("pause");//冻结屏幕
system("cls");//清屏
goto loop;
}
default:return 0;
}
//中止处理
SQLFreeHandle(SQL_HANDLE_STMT, dinghstmt);
SQLDisconnect(dinghdbc);
SQLFreeHandle(SQL_HANDLE_DBC, dinghdbc);
SQLFreeHandle(SQL_HANDLE_ENV, dinghenv);
return 0;
}