资源下载地址:https://download.csdn.net/download/sheziqiong/85837970
资源下载地址:https://download.csdn.net/download/sheziqiong/85837970
列出运行该软件所需要的硬设备。说明其中的新型设备及其专门功能,包括:
操作系统windows系统,数据库管理系统:SQL数据库系统,QTCreator编译工具。
Windows 10系统
用例图从用户角度描述系统功能。该用例图描述系统的参与者仓库管理员与系统的登录、用户管理、供货商管理、商品管理、入库管理、出库管理、报表管理等用例之间的关系。
系统用例图入图1所示:
图 1 用例图
活动图是描述活动的顺序。此系统的活动图分为:出库活动图和入库活动图,它们各自描述了各自与系统进行交互的流程操作。
该出库活动图描述了仓库管理员与系统进行交互的流程操作。
出库活动图如图2所示:
图 2出库活动图
该入库活动图描述了仓库管理员与系统进行交互的流程操作。
入库活动图如图3所示:
图3 入库活动图
类图是描述类,接口以及它们之间关系的图,是一种静态模型,显示了系统中各个类的静态结构。该类图描述超市库存管理系统中的相关类以及各个类的关系来描述静态视图,为的是让开发人员能够更加清楚了解组成该系统的结构。
超市库存管理系统类图如图4所示:
图 4 超市库存管理系统类图
顺序图代表了一个相互作用,在以时间为次序的对象之间的通信集合。
**出库顺序图:**该顺序图描绘了仓库管理员、出库、数据库之间传递消息的时间顺序,以此来表示出库的行为顺序。
出库顺序图如图5所示:
图 5出库顺序图
**入库顺序图:**该顺序图描绘了仓库管理员、入库、数据库之间传递消息的时间顺序,以此来表示入库的行为顺序。
入库顺序图如图6所示:
图6 入库顺序图
状态图主要描述了系统在各个状态之间的转换关系。在进行商品入库操作时,通过点击界面上的各个菜单跳转到各个不同的页面,显示商品的不同状态,各个操作执行完成之后都可以直接返回到系统操作界面,执行其他操作。超市库存管理系统状态图如图9所示:
输入的数据必须符合设计的格式要求:
说明对于该软件的时间特性要求:
要求登陆系统时,系统的响应时间控制在一秒内,更新的时间越低越好, 数据传送时间尽量缩短。
该系统是以C++语言为背景的,应该是可以跨平台运行的,至于操作系统应该也是可以转换在windows操作系统。数据库是SQL Server。
如果需求发生某些变化时,该软件对这些变化的适应能力如下:
系统里已写入默认管理员,输入用户名、密码,即可进入该系统。管理员进入系统界面截图如图10所示。
图10 登录界面截图
bool Mysql::verifyLogin(const QString name,const QString password)
{
QSqlQuery query;
query.exec("select * from [user] where exist = 1");
bool chekname=false;
bool chekpassword=false;
// 打印输出用户名和密码
while (query.next()) {
qDebug() << query.value(0).toInt()
<< query.value(1).toInt()
<< query.value(2).toString();
if(query.value(1).toInt() ==1 ){
chekname = (QString::compare(name,query.value(2).toString(),
Qt::CaseSensitive) == 0);
chekpassword = (QString::compare(password,query.value(3).toString(),
Qt::CaseSensitive) == 0);
}else{
continue;
}
if(chekname&&chekpassword){
return true;
}
}
return false;
}
管理员进入系统后可添加新的用户或者注册新的管理员。注册界面截图如图11所示:
图11注册界面截图
// 当注册页面的注册按下
void Register::on_pushButton_login_clicked()
{
Mysql sql;
if(sql.isUid(ui->lineEdit_id->text().toInt())){
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("编号已存在"));
return;
}
// 用户名是否存在
if(sql.isUname(ui->lineEdit_uname->text())!=-1){
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("用户名已存在"));
return;
}
// 两次密码是否一致
if((QString::compare(ui->lineEdit_password->text(),ui->lineEdit_password_2->text(),
Qt::CaseSensitive) == 0))
{
User user;
user.setId(ui->lineEdit_id->text().toInt());
user.setUname(ui->lineEdit_uname->text());
user.setUpassword(ui->lineEdit_password->text());
user.setExit(1);
int age = ui->lineEdit_age->text().toInt();
if(age>0&&age<200){ // 年龄
user.setAge(age);
}else{
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("年龄错误"));
return;
}
user.setSex(ui->combo_sex->currentText());
user.setTel(ui->lineEdit_tel->text());
if(sql.applyAccount(user)){
user.printUser();
QMessageBox::warning(nullptr, "注意", "用户创建成功");
on_pushButton_clear_clicked();
}
}else { // 两次密码不一样
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("两次密码不一致"));
}
}
仓库管理员可以获取用户管理员界面如图12所示:
图12获取用户界面图
std::vector<User>* Mysql::getUsers()
{
std::vector<User> *List = new std::vector<User>;
QSqlQuery query;
query.exec("select * from [user] where exist = 1");
while (query.next()) {
User user;
user.setId(query.value(0).toInt());
user.setExit(query.value(1).toInt());
user.setUname(query.value(2).toString());
user.setUpassword(query.value(3).toString());
user.setSex(query.value(4).toString());
user.setAge(query.value(5).toInt());
user.setTel(query.value(6).toString());
user.setTime(query.value(7).toDateTime());
List->push_back(user);
}
return List;
}
默认管理员可以通过模糊信息查询用户信息,用户信息模糊查询界面如图13所示:
图13模糊查询界面图
管理员进入商品入库界面,选择供应商、输入商品名称等一系列信息,并选择过期时间。商品入库界面如图14所示:
图14商品入库界面图
void InForm::on_pushButton_in_clicked()
{
QString sname = ui->comboBox->currentText();
QString catename = ui->comboBox_2->currentText();
QString cname = ui->lineEdit->text();
int id = sql.getGoodCid(sname,catename,cname);
if(id == 0){
// 创建商品
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("请先创建新商品"));
return ;
}
int num = ui->spinBox_num->text().toInt();
float price = ui->doubleSpinBox_price->text().toFloat();
float weight = ui->doubleSpinBox__kg->text().toFloat();
if(num <= 0 || price <= 0 || weight <= 0){
ui->label_tip->clear();
ui->label_tip->setStyleSheet(QString("color:red;"));
ui->label_tip->setText(QString("商品数量、价格、质量不能为零"));
return ;
}
QString selftime = ui->dateTimeEdit->dateTime().toString("yyyy-MM-dd hh:mm:ss");
QString tmpSql = QString("INSERT INTO [dbo].[in] ([cid], [price], [time], "
"[shelftime], [num], [uid], [weight] )"
"VALUES"
"( %1, %2, GETDATE(), '%3', %4, %5, %6 )")
.arg(id).arg(price).arg(selftime).arg(num).arg(uid).arg(weight);
qDebug() << tmpSql;
sql.Myexec(tmpSql);
QMessageBox::warning(nullptr, "提示", "入库成功");
ui->label_tip->clear();
}
管理员进入新建商品界面,依次添加信息、选择商品类别、供应商即可成功添加新的商品。新建商品信息界面如图15所示:
图15新建商品信息界面图
void CommodityAddForm::on_pushButton_new_clicked()
{
QString name = ui->lineEdit_cname->text();
QString category = ui->comboBox_category->currentText();
QString suppliername = ui->comboBox->currentText();
if(suppliername.isEmpty()){
this->ui->label_tip->setText("请先选择供应商");
return;
}
int sid = sql.SupplierID(suppliername);
int maxnum = ui->lineEdit_MAX->text().toInt();
int minnum = ui->lineEdit_MIN->text().toInt();
QString tmp = QString("INSERT INTO [dbo].[commodity]([cname],"
" [sid], [category], [minnum], [maxmun]) "
"VALUES ('%1', %2, '%3', %4, %5)")
.arg(name).arg(sid).arg(category)
.arg(minnum).arg(maxnum);
qDebug() << tmp;
sql.Myexec(tmp);
suppliercomboBox();
QMessageBox::warning(nullptr, "提示", "商品信息创建成功");
}
进入供应商界面即可获取所有的供应商信息,输入供应商任一信息即可相对应的供应商信息。获取供应商界面如图16所示:
图16获取供应商界面图**
std::vector<Supplier> *Mysql::getSupplier(QString name)
{
std::vector<Supplier> *list = new std::vector<Supplier>;
QSqlQuery query;
query.exec(QString("select * from [supplier] where exist = 1 and sname LIKE '%%1%'").arg(name));
while (query.next()) {
Supplier supplier;
supplier.setSid(query.value(0).toInt());
supplier.setExist(query.value(1).toInt());
supplier.setSname(query.value(2).toString());
supplier.setAddr(query.value(3).toString());
supplier.setTel(query.value(4).toString());
list->push_back(supplier);
}
return list;
}
点击删除供应商的任一信息即可删除该供应商对应的所有信息。删除供应商界面如图17所示:
图17删除供应商界面图
void SupplierForm::on_pushButton_delete_clicked()
{
int row = ui->tableView->currentIndex().row();
int id = this->model->data(this->model->index(row,0)).toInt();
list[size] =id;
qDebug() << list[size] << "row = " << row;
size++;
model->removeRow(ui->tableView->currentIndex().row());
}
// 点击修改供应商
void SupplierForm::on_pushButton_alter_clicked()
{
int row = ui->tableView->currentIndex().row();
Supplier supplier;
getSupplier(row,supplier);
supplier.printSupplier();
upadteSupplier(supplier);
}
管理员进入商品出库界面,选择供应商以及商品类别即可。出库界面如图18所示:
图18出库界面图
void OutForm::on_pushButton_out_clicked()
{
int row = ui->tableView->currentIndex().row();
int id = this->model->data(this->model->index(row,0)).toInt();
int num = this->model->data(this->model->index(row,2)).toInt();
int outnum = this->model->data(this->model->index(row,8)).toInt();
if(num < outnum){
QMessageBox::warning(nullptr, "警告", "出库数量超过库存");
this->model->setItem(row, 8,new QStandardItem(QString("")));
return;
}
if(outnum <= 0){
QMessageBox::warning(nullptr, "警告", "请输入出库数量");
return;
}
int out = num - outnum;
QString tmp = QString("UPDATE [dbo].[in] "
"SET [num] = %1 WHERE [iid] = %2")
.arg(out).arg(id);
sql.outgood(id,outnum,uid);
qDebug() << tmp;
sql.Myexec(tmp);
QMessageBox::warning(nullptr, "提示", "出库成功");
on_pushButton_refresh_clicked();
}
进出入库界面,在报表类型下拉框中选择入库,在时间下拉框中选择时间段即可导出相应的信息。入库报表管理界面如图19所示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sLBrNNHm-1656579241835)(img/Aspose.Words.33957aab-3b25-4d17-ad3a-a8929c155f1d.015.png)]
图19入库报表管理界面图
进出入库界面,在报表类型下拉框中选择出库,在时间下拉框中选择时间段即可导出相应的信息。出库报表管理界面如图20所示:
图20出库报表管理界面图
void StatementForm::on_pushButton_refresh_clicked()
{
QString IO = ui->comboBox->currentText();
QString time = ui->comboBox_2->currentText();
// 获取当前时间
QDateTime data = QDateTime::currentDateTime();
if(QString::compare(time,QString("一天以内")) == 0){
//data = data.addDays(-1);
time = data.toString("yyyy-MM-dd");
}else if(QString::compare(time,QString("一个月内"))== 0){
data = data.addMonths(-1);
time = data.toString("yyyy-MM-dd");
}else if(QString::compare(time,QString("一个季度内"))== 0){
data = data.addMonths(-3);
time = data.toString("yyyy-MM-dd");
}else if(QString::compare(time,QString("一年以内"))== 0){
data = data.addYears(-1);
time = data.toString("yyyy-MM-dd");
}else{
time = QString("");
}
std::vector<Goods> *Slist;
if(QString::compare(IO,QString("入库")) == 0){
initable(1);
Slist = sql.getinGoods(time);
int i = 0;
for(std::vector<Goods>::iterator it=(*Slist).begin();it!=(*Slist).end();it++){
/*setItem设置条目栏中的一个格子的信息*/
setINTable(i,it);
i++;
}
if(Slist!=NULL)
delete Slist;
Slist = NULL;
}else{
initable(2);
Slist = sql.getoutGoods(time);
int i = 0;
for(std::vector<Goods>::iterator it=(*Slist).begin();it!=(*Slist).end();it++){
/*setItem设置条目栏中的一个格子的信息*/
setOUTable(i,it);
i++;
}
if(Slist!=NULL)
delete Slist;
Slist = NULL;
}
qDebug() << uid << "id id";
qDebug() << data.toString("yyyy-MM-dd") << " " << IO ;
}
进入商品信息管理界面,在供应商下拉框中选择供应商,在商品类别下拉框中选择商品类别即可导出相应的信息。商品管理界面如图21所示:
图21商品管理界面图
void GoodManangeForm::on_pushButton_find_clicked()
{
initTable();
QString sname = ui->comboBox->currentText();
QString catename = ui->comboBox_2->currentText();
qDebug() << sname << " " << catename;
std::vector<Goods> *Slist = sql.getGoods(sname,catename);
int i = 0;
for(std::vector<Goods>::iterator it=(*Slist).begin();it!=(*Slist).end();it++){
/*setItem设置条目栏中的一个格子的信息*/
setTable(i,it);
i++;
}
if(Slist!=NULL)
delete Slist;
Slist = NULL;
}
实时更新警告,一分钟更新一次。
警告商品过期界面如图22所示:
图22警告商品过期界面图
警告商品即将过期界面如图23所示:
图23警告商品即将过期界面图
警告商品库存不足界面如图24所示:
图24警告商品库存不足界面图
警告商品库存过量界面如图25所示:
图25警告商品库存过量界面图
void WarningForm::settableGoods(int i, std::vector<Goods>::iterator s)
{
s->printGoods();
this->model->setItem(i, 0, new QStandardItem(QString("%1").arg(s->getCid())));
this->model->setItem(i, 1, new QStandardItem(QString(s->getCname())));
this->model->setItem(i, 2, new QStandardItem(QString("%1").arg(s->getNum())));
this->model->setItem(i, 3, new QStandardItem(QString(s->getCategory())));
this->model->setItem(i, 4, new QStandardItem(QString(s->getSnmae())));
this->model->setItem(i, 5, new QStandardItem(QString(s->getAddr())));
this->model->setItem(i, 6, new QStandardItem(QString(s->getTel())));
}
void WarningForm::Overdue()
{
ui->label->clear();
ui->label->setText(QString("警告商品过期"));
std::vector<Goods> goodlist = getgoods();
int i = 0;
for(std::vector<Goods>::iterator it=goodlist.begin();it!=goodlist.end();it++){
/*setItem设置条目栏中的一个格子的信息*/
settable(i,it);
i++;
}
}
void WarningForm::Expiring()
{
ui->label->clear();
ui->label->setText(QString("警告商品即将过期"));
std::vector<Goods> goodlist = getExpiringgoods();
int i = 0;
for(std::vector<Goods>::iterator it=goodlist.begin();it!=goodlist.end();it++){
/*setItem设置条目栏中的一个格子的信息*/
settable(i,it);
i++;
}
}
void WarningForm::lack()
{
ui->label->clear();
ui->label->setText(QString("警告商品库存不足"));
std::vector<Goods> goodlist = getlackgoods();
int i = 0;
for(std::vector<Goods>::iterator it=goodlist.begin();it!=goodlist.end();it++){
/*setItem设置条目栏中的一个格子的信息*/
settableGoods(i,it);
i++;
}
}
void WarningForm::nimiety()
{
ui->label->clear();
ui->label->setText(QString("警告商品库存过量"));
std::vector<Goods> goodlist = getnimietygoods();
int i = 0;
for(std::vector<Goods>::iterator it=goodlist.begin();it!=goodlist.end();it++){
/*setItem设置条目栏中的一个格子的信息*/
settableGoods(i,it);
i++;
}
}
bool WarningForm::ifOverdue()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where shelftime < GETDATE()"));
query.next();
return !query.value(1).toString().isEmpty();
}
bool WarningForm::ifExpiring()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where shelftime < GETDATE()+30 and shelftime > GETDATE()"));
query.next();
return !query.value(1).toString().isEmpty();
}
bool WarningForm::iflack()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where num < minnum"));
query.next();
return !query.value(1).toString().isEmpty();
}
bool WarningForm::ifnimiety()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where num > maxmun"));
query.next();
return !query.value(1).toString().isEmpty();
}
ing().isEmpty();
}
bool WarningForm::ifExpiring()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where shelftime < GETDATE()+30 and shelftime > GETDATE()"));
query.next();
return !query.value(1).toString().isEmpty();
}
bool WarningForm::iflack()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where num < minnum"));
query.next();
return !query.value(1).toString().isEmpty();
}
bool WarningForm::ifnimiety()
{
QSqlQuery query;
query.exec(QString("SELECT * from goodsin where num > maxmun"));
query.next();
return !query.value(1).toString().isEmpty();
}
资源下载地址:https://download.csdn.net/download/sheziqiong/85837970
资源下载地址:https://download.csdn.net/download/sheziqiong/85837970