库存自动盘点问题

syskey000003 2004-11-11 11:59:43
我想通过一个按键来实际数据库内自动盘点的功能,功能很简单就是从现有的库存中减去同样产品的销售数量等一些字段,代码如下。
Private Sub Command1_Click()
sql = "select * from 库存表"
rs.CursorLocation = adUseClient
rs.Open sql, cn, adOpenKeyset, adLockPessimistic
If rs.RecordCount = 0 Then
MsgBox "当前库存数不存在!", vbOKOnly + vbExclamation, "注意"
rs.Close
Exit Sub
End If

rs.MoveFirst
For i = 1 To rs.RecordCount
sql = "select sum(片数),sum(面积) from 销售单 where 序号=" & rs.Fields(1)
gu.Open sql, cn, adOpenKeyset, adLockPessimistic
If gu.RecordCount > 0 Then
rs.Fields(3) = rs.Fields(3) - gu.Fields(0)
rs.Fields(4) = rs.Fields(4) - gu.Fields(1)
End If
rs.Update
gu.Close
rs.MoveNext
Next i
rs.Close
End Sub

我的后台数据库用的是access,结果运行后库存表内片数,面积字段全部为空。
同时我也用了其它的方法,来判断gu.fields(0)是否为空,如果为空库存表内字段不变,可依旧不行搞了两天了还不行,哪位老大知道的话帮忙看看。顺便把源代码帮忙改一下看看是不是哪里错了。
...全文
150 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
Abyss-Xu 2004-11-30
  • 打赏
  • 举报
回复
sql = "select sum(片数),sum(面积) from 销售单 where 序号=" & rs.Fields(1)
改成
sql = "select sum(片数),sum(面积) from 销售单 where 序号=" & rs(1)
Abyss-Xu 2004-11-30
  • 打赏
  • 举报
回复
rs(3) = rs(3) - gu.(0)
rs(4) = rs(4) - gu(1)
是这样
Abyss-Xu 2004-11-30
  • 打赏
  • 举报
回复
rs(3) = (3) - gu.(0)
rs(4) = (4) - gu(1)
去掉 .fields
gordon1979 2004-11-30
  • 打赏
  • 举报
回复
试试:先把gu记录集保存在相应变量中,然后判断是否为空来进行相应的操作。
我觉得每次销售后从库存中减去相应的数量比较好,因为你这个应该是单机版的,速度不会很慢,这样以后根本不用去处理这些问题。
minghui000 2004-11-30
  • 打赏
  • 举报
回复
up
syskey000003 2004-11-13
  • 打赏
  • 举报
回复
没人知道了吗,为什么在VB里面,一个数减掉一个空值之后也变成空值了呢,怎么做才能不变呢。
pweixing 2004-11-11
  • 打赏
  • 举报
回复
有那么麻烦吗?
如果"select * from 库存表"的结果不为空的话,直接一个sql语句不就解决了吗?为什么要搞循环呢?
update 库存表 set Fields(3)=Fields(3)-销售单.sum(片数),Fields(4)=Fields(4)-销售单.sum(面积) where 销售单.序号=库存表.Fields(0)

cosio 2004-11-11
  • 打赏
  • 举报
回复
首先确定sql里面有数据!
跟踪调 试 一 下!

rs.Fields(3) = rs.Fields(3) - gu.Fields(0)
rs.Fields(4) = rs.Fields(4) - gu.Fields(1)       //??????????????????
syskey000003 2004-11-11
  • 打赏
  • 举报
回复
楼上的,你的方法是很好,一个语句就可以了,可是在VB里面它不行呀。
库存表有五个字段,第一个是序号,第二三不重要,第四个是片数,第五是面积。
销售单里如果没有销售的话减掉后就会出现空值在VB里面不是原先的数。而且在FOR 循环里只能用IF END IF 条件判断条件,不可以用ELSE。
而且上面的话句,运行不了.
演示下载: http://demo.codechina.net/vf/tsjxc.exe 总部主系统 1 功能 1.1 进货管理 1.1.1 进货单查询、录入、修改、删除、恢复。并将进货数据传至库存模块,经库存审核后自动录入库存库。 1.1.2 缺货清单查询。 1.1.3 退货(退厂)数据查询、打印。根据库存库退货出库所传来的数据自动录入。 1.1.4 统计进货数据,查看和打印统计结果。统计的项目为: 1.1.4.1 任意时段所有商品的进货、退货、保修金额合计。 1.1.4.2 任意时段某一商品的进货、退货、保修数量、金额合计。 1.1.4.3 到目前为止尚未保修返回的金额合计。 1.1.4.4 任意时段所有供应商的进货、退货、保修金额合计。 1.1.4.5 任意时段某一供应商的进货、退货、保修金额合计。 1.1.5 供应商查询、录入、修改、删除、恢复。 1.1.6 保修(保修退厂)数据查询、打印、返回核消。根据库存库保修出库所传来的数据自动审核录入。 1.2 库存管理 1.2.1 初始化库存,录入商品的初始库存数,一旦总帐中已有该商品,则不能再录入初始数。 1.2.2 进、出库数据查询、录入、修改、删除、恢复。审核及自动录入进货模块和代销模块由于进货、出货、退货及保修传来的进出库数据。打印进出库单。 1.2.3 设定商品库存下限。在库存低于下限时报警,并出具下限报警商品清单给进货模块。 1.2.4 盘点。查看、打印盘点表。录入盘盈、盘亏数据。盘亏的数据做为报费数进行统计。残次品库的盘点,盘盈、盘亏数直接在残次品库中处理。 1.2.5 (暂不使用)残次品、报费数据的输入。正品转残次品,从仓库总帐及日记帐中做出库处理,自动转到残次品库;残次品转正品,则自动从残次品库中出库转向总库,总帐及日记帐中做入库处理。 1.2.6 库存数据统计,查看、打印统计数据。统计的项目为: 1.2.6.1 统计到目前为止所有商品的数量、金额合计。 1.2.6.2 任意时段所有商品的进库、出库数量、金额合计。 1.2.6.3 任意时段某一商品的进库、出库数量、金额合计。 1.2.6.4 到目前为止残次品的库存金额合计。 1.2.6.5 任意时段所有商品的报费金额合计。 1.2.6.6 任意时段某一商品的报费数量、金额合计。 1.3 销售管理 1.3.1 记录每一笔销售数据。录入、修改、删除、恢复、查看每一笔从总部的仓库中直接销售出去的数据。并将销售数据自动传送到库存模块用于审核及自动录入。 1.3.2 退货管理。录入、修改、删除、恢复、查看有关退货的数据,并将退货数据自动传给库存模块,由库存审核后自动录入。 1.3.3 保修管理。录入、修改、删除、恢复、查看有关保修的数据,返回核消,并将保修数据自动传给库存模块,由库存审核后自动录入。 1.3.4 统计销售数据,并查看和打印统计数据,按金额排序,标记出数量最多的商品。统计的项目为: 1.3.4.1 任意时段所有商品的销售金额、合计。 1.3.4.2 任意时段某一商品的销售数量、金额合计。 1.4 代销管理 1.4.1 出货单管理。记录每一笔出货给代销商的数据。并将数据传给库存模块,经审核后自动录入。 1.4.2 结算管理。根据出货单中的金额数据记录应付款,代销商每付一笔款,即从结算款中减去相应的数额,余额继续做为应付款。 1.4.3 销售管理。录入、修改、删除、恢复代销商传来的有关销售数据,传送的方式可用纸质、磁盘、电话线。根据销售数计算并自动录入代销点的库存数。 1.4.4 退货(退仓)数据录入、修改、删除、恢复、查看。并将退货数据传给库存模块,由库存审核后自动录入。 1.4.5 保修(保修退仓)数据录入、修改、删除、恢复、查看。并将保修数据传给库存模块,由库存审核后自动录入。 1.4.6 销售统计,并查看和打印统计数据。统计的范围包括某一代销商、全部代销商、包括仓库直接销售,统计的项目为: 1.4.6.1 任意时段所有商品的销售金额、成本、利润合计。 1.4.6.2 任意时段某一商品的销售数量、金额、成本、利润合计。 1.4.6.3 任意时段销售数量、营业额、成本、利润最多、最少的商品。 1.4.6.4 到目前为止,盘点库存数与上报销售数所推算出的库存数的差额,分别包括数量和金额。 1.4.6.5 任意时段退货金额。 1.4.6.6 任意时段保修金额,及到目前为止尚未保修返还的商品、数量、金额。 1.4.6.7 到目前为止的各代销商及总的应收款金额合计。 1.4.7 盘点。查看、打印盘点表。录入盘点库存数,但不用盘点数修正根据销售数所得的库存数,两个数据都要,并在统计中做比较,以了解代销商押总部货款的数额。 1.5 辅助功能 1.5.1 工作人员管理。 1.5.2 备份。 1.5.3 取备份。 1.5.4 密码管理。 1.5.5 整理数据。将所有数据库重新索引,稽核相关数据。 1.5.6 退出系统。 1.5.7 确认系统日期和时间。 ................... 内容详细文档

1,217

社区成员

发帖
与我相关
我的任务
社区描述
VB 数据库(包含打印,安装,报表)
社区管理员
  • 数据库(包含打印,安装,报表)社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧