入库出库查询软件——qt
miniMes系统操作说明
一:功能说明
主界面有扫描--查询两个界面,扫描界面如下
1:默认开启自动入库出库功能
2:右上角限制位数可根据需求设定二维码字符串的位数,设置完成后点击设定,弹窗设定成功即可
3:运行逻辑如下,鼠标点击二维码输入框,扫描二维码,未入库的产品会执行《入库操作》
4:两秒内再次扫描该产品(输入同样的二维码)不会触发《出库操作》,若是扫描其他产品则会正常入库与出库,该功能主要为了避免二维码扫描周期太快造成的重复输入
5:两秒后扫描产品,已经入库的产品会执行《出库操作》
6:查询界面如下图所示:
7:输入二维码可以查询该产品的入库与出库时间,双击QR可修改QR
8:选择开始与结束时间,点击导出会生成对应时间段的csv文件(名称为开始时间),时间段依据是入库时间
二:软件运行说明
1:mes文件对应存储的所有二维码数据,目前测试10万数据约500k,所以长时间内无需清理,如果明显感到入库,出库与查询的时间很长,需要将该文件修改名称即可(最好以日期区分),修改名称后我会自动创建mes文件进行存储
部分代码:
- 查询出入库
点击查看代码
bool MesMini::isBePutInStore(const QString &qrStr)
{
//model->clear();
try
{
//eg: "select * from LoginTable where USERNAME == 'user0';"
QSqlQuery sql_query("select * from QRTable where QR == '" + qrStr + "';");
if (!sql_query.exec())
{
QMessageBox::critical(NULL, "Prompt", sql_query.lastError().text());
return false;
}
else
{
if (sql_query.next()) {
return false;
} else {
// 没有结果
return true;//可以入库了
}
}
}
catch (...)
{
return false;
}
}
- 出库操作
点击查看代码
void MesMini::autoInsert_slot(const QString &strTmp){
index = ui->spinBox->value();
if(strTmp == ""){
return;
}
int charCount = strTmp.length();
if(charCount != index){
return;
}
//查询是否入库
if(isBePutInStore(strTmp)){
//开始入库操作
QDateTime currentTime = QDateTime::currentDateTime();
QString formattedTime = currentTime.toString("yyyy-MM-dd HH:mm:ss ");
bool isInsert = InsertData("QRTable",formattedTime,"",strTmp);
if(isInsert){
appendToLog(strTmp + QStringLiteral(" 入库成功"));
ui->lineEdit_QRInsert->clear();
lastQrStr = strTmp;
startTime = QTime::currentTime();
}
else{
appendToLog(strTmp + QStringLiteral(" 入库失败"));
}
return;
}
//是否入库未出库
if(lastQrStr == strTmp){
endTime = QTime::currentTime();
int millis = fabs(endTime.msecsTo(startTime));
if(millis < 2000){
ui->lineEdit_QRInsert->clear();
return;
}
}
if(isNotOutOfStore(strTmp)){
//开始出库操作
QDateTime currentTime = QDateTime::currentDateTime();
QString formattedTime = currentTime.toString("yyyy-MM-dd HH:mm:ss ");
bool isUpdate = updateSql(formattedTime,strTmp);
if(isUpdate){
appendToLog(strTmp + QStringLiteral(" 出库成功"));
ui->lineEdit_QRInsert->clear();
}
else{
appendToLog(strTmp + QStringLiteral(" 出库失败"));
}
return;
}
}
入库出库查询软件——qt的更多相关文章
- HTML5 Canvas 绘制库存变化折线 画入库出库柱状图
代码: <!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Type ...
- 练习1:python设计停车入库出库系统
前言: 最近在某个测试群看到有人抛出了一个面试题.为了提升自己的编程能力,我也尝试的用python去写了一下. 语言:python,数据库:sqlite .菜鸟来袭,只是基本实现功能,可能没有考虑太 ...
- 使用Jasperreporter生成入库出库单打印等报表操作
项目需要打印报表:就是那种生成入库单,出库单等的操作.使用到的技术:使用iReport Designer5.1.0设计报表,使用struts2+jasperreporter生成最终填充数据的报表 首先 ...
- php解析入库跟出库
转载:http://www.jb51.net/article/39092.htm 数据放入数据库和取出来显示在页面需要注意什么 入库时 $str=addslashes($str); $sql=\&qu ...
- MySQL_产品昨日库存与历史入库历史出库成本_20161124
产品昨日库存与历史入库历史出库成本 SELECT d.ID,a.*,e.昨日订单额 ,b.昨天入库额,b.历史2天,b.历史3天,b.历史4天,b.历史5天,b.历史6天,b.历史7天,b.历史8天, ...
- Java 框架、库和软件的精选列表(awesome java)
原创翻译,原始链接 本文为awesome系列中的awesome java Awesome Java Java 框架.库和软件的精选列表 项目 Bean映射 简化 bean 映射的框架 dOOv - 为 ...
- SAP MM 并非奇怪现象之MB5B报表查不到某一笔出库记录?
物料号:1301002696 工厂代码:2160 MB5B,如下查询条件, 查询结果中,期初与期末库存数量都是0,期间的出库入库数量都是0.事实上该物料期初应该是有库存的.并且我用MB51相同时间段查 ...
- ERP出库审核业务(四十四)
结束表单流程的代码: protected void btnSubmit_Click(object sender, EventArgs e) { if(this.txtreceiveDate.Text! ...
- U811.1接口EAI系列之二--生成销售出库单调用U8的EAI通用处理方法--PowerBuilder语言
1.销售系统销售出库,更新U811.1材料库存的EAI的XML生成. 2.主要根据U8配置会生成出库单和同时是否更新库存量,还是更新现存量等等. 3.具体参考代码如下: 作者:王春天 2013-11- ...
- SQL用先进先出存储过程求出库数量
create table t( id ,), name ),--商品名称 j int, --入库数量 c int, --出库数量 jdate datetime --入库时间 ) ,,'2007-12- ...
随机推荐
- Linux 安装配置Anaconda
下载地址 https://www.anaconda.com/download/success 选择系统版本,复制链接 wget https://repo.anaconda.com/archive/An ...
- Invalid prop: type check failed for prop "showCheckbox". Expected Boolean, got String.
一个简单的报错 ,可以用于 代码: <el-tree :data="menus" :props="defaultProps" ...
- Cursor 老改坏代码?六哥这几招超管用!
大家好,我是六哥!最近不少小伙伴和我吐槽,在使用Cursor时,AI老是把代码改坏,让人头疼不已.我自己也用了大几十个小时Cursor,今天就来给大家分享一些实用小窍门,教大家如何巧妙规避这类问题. ...
- Ollama本地部署大模型总结
日拱一卒,功不唐捐 今天计划对之前ollama系列做个回顾,从如何部署到API使用,整理到一篇内容中,提供给大家参考. 安装指南 第一步:安装ollama 我们可以从官网下载ollama,此步骤支持w ...
- Hyperledger Fabric - 区块链应用
Fabric Gateway SDK 实现Fabric的编程模型,提供了一系列简单的API给应用程序与Fabric区块链网络进行交互 应用程序将各自的网络交互委托给其网关,每个网关都了解网络信道拓扑, ...
- JBoltAI Function Call技术解析:如何实现AI模型与企业系统的无缝对话
JBoltAI Function Call技术解析: 如何实现AI模型与企业系统的无缝对话 在企业级AI应用开发中,如何让大模型能力与现有系统高效协同一直是技术难点.JBoltAI框架通过Functi ...
- 比df更好用的命令!
大家好,我是良许. 对于分析磁盘使用情况,有两个非常好用的命令:du 和 df .简单来说,这两个命令的作用是这样的: du 命令:它是英文单词 disk usage 的简写,主要用于查看文件与目录占 ...
- Aspnet Core 10 Preview3已对最小API提供参数验证支持
前言 相信大家都或多或少用上了Minimal API,快速简洁,性能炸裂,是快速开发API端口的不二之选!但是呢目前正式版为止 最小API还并不内置支持对请求参数的内置验证支持,比如[Required ...
- IOC 中 bean 标签
- SpringBoot3整合SpringSecurity6(一)快速入门
大家好,我是晓凡. 写在前面 不知道小伙伴们在学SpringSecurity过程中有没有和我一样的经历和烦恼. ①看完一篇文章或者一个教程,感觉学会了.但是一到实际项目中就不知道怎么用: ②被Spri ...