📄 frmouth1.frm
字号:
Style = 2 'Dropdown List
TabIndex = 3
Top = 240
Width = 1572
End
Begin VB.TextBox txtItem
Height = 276
Index = 8
Left = 3720
MaxLength = 200
MultiLine = -1 'True
TabIndex = 2
Top = 240
Width = 2052
End
Begin VB.Label Label2
Caption = "预付比例:"
Height = 252
Index = 13
Left = 2880
TabIndex = 5
Top = 240
Width = 1092
End
Begin VB.Label Label2
Caption = "方式选择:"
Height = 252
Index = 14
Left = 360
TabIndex = 4
Top = 240
Width = 1092
End
End
Begin VB.TextBox txtItem
Height = 276
Index = 10
Left = 480
MaxLength = 200
MultiLine = -1 'True
TabIndex = 0
Top = 7800
Visible = 0 'False
Width = 492
End
End
Attribute VB_Name = "frmOUTH1"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
Option Explicit
'是否改动过记录,ture为改过
Dim mblChange As Boolean
Dim mrc As ADODB.Recordset
Public txtSQL As String
Private Sub cmdExit_Click()
If mblChange And cmdSave.Enabled Then
If MsgBox("保存当前记录的变化吗?", vbOKCancel + vbExclamation, "警告") = vbOK Then
'保存
Call cmdSave_Click
End If
End If
Unload Me
End Sub
Private Sub cmdSave_Click()
Dim intCount As Integer
Dim sMeg As String
Dim MsgText As String
Dim mrce As ADODB.Recordset
For intCount = 1 To 7
If Trim(txtItem(intCount) & " ") = "" Then
Select Case intCount
Case 1
sMeg = "销售单号"
Case 2
sMeg = "客户代码"
Case 3
sMeg = "商品代码"
Case 4
sMeg = "数量"
Case 5
sMeg = "销售单价"
Case 6
sMeg = "折扣比例"
Case 7
sMeg = "总金额"
End Select
sMeg = sMeg & "不能为空!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
txtItem(intCount).SetFocus
Exit Sub
End If
Next intCount
If txtItem(8).Visible = True Then
If Trim(txtItem(8) & " ") = "" Then
sMeg = "预付比例不能为空!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
txtItem(8).SetFocus
Exit Sub
End If
End If
If Trim(txtItem(11)) = "" Then
MsgBox "请输入药品的有效期限!", vbOKOnly + vbExclamation, "警告"
txtItem(11).SetFocus
Exit Sub
End If
If Not IsDate(Format(Trim(txtItem(11)), "yyyy-mm-dd")) Then
MsgBox "药品的有效期限请输入日期!", vbOKOnly + vbExclamation, "警告"
txtItem(11).SetFocus
Exit Sub
End If
For intCount = 0 To 2
If Trim(Combo1(intCount) & " ") = "" Then
Select Case intCount
Case 0
sMeg = "业务员"
Case 1
sMeg = "客户名称"
Case 2
sMeg = "商品名称"
End Select
sMeg = sMeg & "不能为空!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Combo1(intCount).SetFocus
Exit Sub
End If
Next intCount
For intCount = 4 To 5
If Trim(Combo1(intCount) & " ") = "" Then
Select Case intCount
Case 4
sMeg = "仓库名称"
Case 5
sMeg = "支付方式"
End Select
sMeg = sMeg & "不能为空!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Combo1(intCount).SetFocus
Exit Sub
End If
Next intCount
For intCount = 4 To 7
If Not IsNumeric(Trim(txtItem(intCount))) Then
sMeg = "请输入数字!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
txtItem(intCount).SetFocus
Exit Sub
End If
Next intCount
If txtItem(8).Visible = True Then
If Not IsNumeric(Trim(txtItem(8))) Then
sMeg = "预付比例请输入数字!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
txtItem(8).SetFocus
Exit Sub
End If
End If
'添加判断是否有相同的ID记录
If gintOUTHmode = 1 Then
txtSQL = "select * from outh where outh_no ='" & Trim(txtItem(1)) & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
If mrc.EOF = False Then
MsgBox "已经存在此销售单编号的记录!", vbOKOnly + vbExclamation, "警告"
txtItem(1).SetFocus
Exit Sub
End If
mrc.Close
End If
If gintOUTHmode = 1 Then
txtSQL = "select update_date,sl,total_je from kucun where ckdm = '" & txtItem(10) & "'"
txtSQL = txtSQL & " and wzdm = '" & txtItem(3) & "'"
txtSQL = txtSQL & " and cxend = '" & txtItem(11) & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
If Not mrc.EOF Then
If mrc.Fields(1) >= CDbl(txtItem(4)) Then
mrc.Fields(0) = txtItem(0)
mrc.Fields(1) = mrc.Fields(1) - txtItem(4)
mrc.Fields(2) = mrc.Fields(2) * (mrc.Fields(1)) / (mrc.Fields(1) + txtItem(4))
mrc.Update
mrc.Close
If Option1(0).Value Then
txtSQL = "select total_je from dm_kh where dm = '" & Trim(txtItem(2)) & "'"
Set mrce = ExecuteSQL(txtSQL, MsgText)
If Not mrce.EOF Then
mrce.Fields(0) = mrce.Fields(0) + txtItem(7)
mrce.Update
mrce.Close
End If
ElseIf Option1(1).Value Then
txtSQL = "select total_je from dm_khs where dm = '" & Trim(txtItem(2)) & "'"
Set mrce = ExecuteSQL(txtSQL, MsgText)
If Not mrce.EOF Then
mrce.Fields(0) = mrce.Fields(0) + txtItem(7)
mrce.Update
mrce.Close
End If
End If
Else
mrc.Close
sMeg = "库存商品数量不够,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
Else
sMeg = "仓库没有指定商品,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
ElseIf gintOUTHmode = 2 Then
If (txtCKDM = txtItem(10)) And (txtWZDM = txtItem(3)) And (txtQIHAO = txtItem(11)) Then
txtSQL = "select update_date,sl,total_je from kucun where ckdm = '" & txtCKDM & "'"
txtSQL = txtSQL & " and wzdm = '" & txtWZDM & "'"
txtSQL = txtSQL & " and cxend = '" & txtQIHAO & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
If Not mrc.EOF Then
If (mrc.Fields(1) + CDbl(txtSL)) >= CDbl(txtItem(4)) Then
mrc.Fields(0) = txtItem(0)
mrc.Fields(1) = mrc.Fields(1) + txtSL - txtItem(4)
mrc.Fields(2) = mrc.Fields(2) * (mrc.Fields(1)) / (mrc.Fields(1) - txtSL + txtItem(4))
mrc.Update
mrc.Close
Else
mrc.Close
sMeg = "库存商品数量不够,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
Else
sMeg = "仓库中没有指定商品,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
Else
txtSQL = "select update_date,sl,total_je from kucun where ckdm = '" & txtItem(10) & "'"
txtSQL = txtSQL & " and wzdm = '" & txtItem(3) & "'"
txtSQL = txtSQL & " and cxend = '" & txtItem(11) & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
If Not mrc.EOF Then
If mrc.Fields(1) >= CDbl(txtItem(4)) Then
mrc.Fields(0) = txtItem(0)
mrc.Fields(1) = mrc.Fields(1) - txtItem(4)
mrc.Fields(2) = mrc.Fields(2) * (mrc.Fields(1)) / (mrc.Fields(1) + txtItem(4))
mrc.Update
mrc.Close
Else
mrc.Close
sMeg = "库存商品数量不够,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
Else
sMeg = "仓库没有指定商品,请首先从其他仓库调拨!"
MsgBox sMeg, vbOKOnly + vbExclamation, "警告"
Exit Sub
End If
txtSQL = "select update_date,sl,total_je from kucun where ckdm = '" & txtCKDM & "'"
txtSQL = txtSQL & " and wzdm = '" & txtWZDM & "'"
txtSQL = txtSQL & " and cxend = '" & txtQIHAO & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
If Not mrc.EOF Then
mrc.Fields(0) = txtItem(0)
mrc.Fields(1) = mrc.Fields(1) + txtSL
mrc.Fields(2) = mrc.Fields(2) * (mrc.Fields(1)) / (mrc.Fields(1) - txtSL)
mrc.Update
End If
mrc.Close
End If
End If
'先删除已有记录
txtSQL = "delete from outh where outh_no ='" & Trim(txtItem(1)) & "'"
Set mrc = ExecuteSQL(txtSQL, MsgText)
'再加入新记录
txtSQL = "execute outh_setup '"
txtSQL = txtSQL & Trim(txtItem(0)) & "','"
txtSQL = txtSQL & Trim(Combo1(0).ItemData(Combo1(0).ListIndex)) & "','"
For intCount = 1 To 2
txtSQL = txtSQL & Trim(txtItem(intCount)) & "','"
Next intCount
txtSQL = txtSQL & Trim(txtItem(10)) & "','"
txtSQL = txtSQL & Trim(txtItem(3)) & "','"
txtSQL = txtSQL & Trim(txtItem(11)) & "','"
For intCount = 4 To 7
txtSQL = txtSQL & Trim(txtItem(intCount)) & "','"
Next intCount
If Combo1(5).ListIndex = 0 Then
txtSQL = txtSQL & "Y','N','0','"
ElseIf Combo1(5).ListIndex = 1 Then
txtSQL = txtSQL & "N','Y','0','"
ElseIf Combo1(5).ListIndex = 2 Then
txtSQL = txtSQL & "N','N','" & Trim(txtItem(8)) & "','"
End If
txtSQL = txtSQL & Trim(txtItem(9)) & "','"
If Option1(0).Value Then
txtSQL = txtSQL & "1'"
ElseIf Option1(1).Value Then
txtSQL = txtSQL & "2'"
End If
Set mrc = ExecuteSQL(txtSQL, MsgText)
If gintOUTHmode = 1 Then
MsgBox "添加记录成功!", vbOKOnly + vbExclamation, "添加记录"
For intCount = 0 To 9
txtItem(intCount) = ""
Next intCount
txtItem(11) = ""
For intCount = 0 To 2
Combo1(intCount).ListIndex = 0
Next intCount
For intCount = 4 To 5
Combo1(intCount).ListIndex = 0
Next intCount
txtItem(0) = Format(Now, "yyyy-mm-dd")
mblChange = False
Unload frmOUTH
frmOUTH.txtSQL = "select outh_no,out_date,ywman,khdm,ckdm,wzdm,cxend,sl,out_danj,o_zk,o_zke,jsfk,jz,yf,bz,bz1 from outh"
frmOUTH.Show
ElseIf gintOUTHmode = 2 Then
Unload Me
Unload frmOUTH
frmOUTH.txtSQL = "select outh_no,out_date,ywman,khdm,ckdm,wzdm,cxend,sl,out_danj,o_zk,o_zke,jsfk,jz,yf,bz,bz1 from outh"
frmOUTH.Show
End If
End Sub
Private Sub Combo1_Change(Index As Integer)
mblChange = True
End Sub
Private Sub Combo1_Click(Index As Integer)
Dim mrcc As ADODB.Recordset
Dim mrcd As ADODB.Recordset
Dim MsgText As String
If Index = 1 Then
txtItem(2) = Combo1(1).ItemData(Combo1(1).ListIndex)
If Option1(0).Value = False And Option1(1).Value = True Then
txtSQL = "select lbcode,total_je from dm_khs where dm = '" & Trim(Combo1(1).ItemData(Combo1(1).ListIndex)) & "'"
Set mrcc = ExecuteSQL(txtSQL, MsgText)
If Not mrcc.EOF Then
If mrcc.Fields(1) = 0 Then
txtItem(12) = "基本个人会员"
txtItem(13) = 0
txtItem(6) = 100
Else
txtItem(13) = mrcc.Fields(1)
txtSQL = "select lbcode,lb,least_je,mb_reb from dm_khlb where bz = '2' order by least_je "
Set mrcd = ExecuteSQL(txtSQL, MsgText)
If Not mrcd.EOF Then
Do While Not mrcd.EOF
If mrcc.Fields(1) < mrcd.Fields(2) Then
mrcd.MovePrevious
txtItem(12) = mrcd.Fields(1)
txtItem(6) = mrcd.Fields(3)
Exit Do
Else
mrcd.MoveNext
End If
Loop
mrcd.Close
End If
End If
mrcc.Close
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -