管家婆二次开发—未完成销售订单监控

王世权 技术分享评论5,832 views阅读模式

管家婆二次开发

管家婆是一款通用的进销存软件,本文以一个范例介绍如何对管家婆进行二次开发,以满足用户的个性化需求。

需求分析

为防止客户货重复申报造成销售订单重复的情况,对一个客户出现多个未完成销售订单时,自动弹出提示。

准备工作

管家婆没有提供开发接口,对其的二次开发主要通过对其数据库的监控来实现,因此首先要了解其数据字典,可参照《管家婆数据字典》
本次开发用到的表有:订单索引表(DlyndxOrder)、往来单位明细表(btype)

数据库二次开发

在订单索引表中没有订单的建立时间,我们需要新增一列,并建立索引以加快查询速度。

  1. alter table DlyndxOrder add CreateDate datetime not null default getdate()
  2. go
  3. CREATE NONCLUSTERED INDEX [CreateDate] ON [dbo].[DlyNdxOrder]
  4. (
  5.     [CreateDate] ASC
  6. )WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ONON [PRIMARY]
  7. go

程序实现

1、让客户选择是否在本客户端监控以及监控周期。(监控周期指的是多长时间扫描一次数据库同时也是判断销售订单的建立时间是否在提示范围内,避免重复提示的情况。)

代码略

2、通过Timer组件进行循环监控。

  1. Private Sub TimerDDJK_Tick(ByVal sender As Object, ByVal e As System.EventArgs) Handles TimerDDJK.Tick
  2.         Using sqlconn As SqlConnection = New SqlConnection(ConnStr)
  3.             Dim cmd As SqlCommand = New SqlCommand
  4.             cmd.Connection = sqlconn
  5.             cmd.Parameters.AddWithValue("@监控周期", ddjk)
  6.             cmd.CommandText = "select distinct c.fullname" _
  7.             & " from DlyndxOrder a inner join" _
  8.             & " DlyndxOrder b on a.btypeid=b.btypeid and a.vchcode<>b.vchcode inner join" _
  9.             & " btype c on a.btypeid=c.typeid" _
  10.             & " where a.orderover = 0 And a.userover = 0 And b.orderover = 0 And b.userover = 0 and a.vchType=8" _
  11.             & " and getdate()<dateadd(s,@监控周期,a.CreateDate)" _
  12.             & " order by c.fullname"
  13.             Dim dap As SqlDataAdapter = New SqlDataAdapter
  14.             Dim dtb As DataTable = New DataTable
  15.             dap.SelectCommand = cmd
  16.             Try
  17.                 dap.Fill(dtb)
  18.                 If dtb.Rows.Count > 0 Then
  19.                     Dim i As Integer
  20.                     Dim s As New System.Text.StringBuilder
  21.                     For i = 0 To dtb.Rows.Count - 1
  22.                         s.Append(dtb.Rows(i).Item("fullname") & " ")
  23.                     Next
  24.                     MsgBox("以下客户出现多个未完成订单:" & Microsoft.VisualBasic.vbCrLf & s.ToString, MsgBoxStyle.Information, "提示")
  25.                 End If
  26.             Catch ex As Exception
  27.                 MsgBox(ex.Message)
  28.             End Try
  29.         End Using
  30.     End Sub

本文介绍了管家婆二次开发的思路,管中窥豹,其他企业管理软件二次开发也可参照。

end

  • 工资小程序
  • 员工工资查询小程序
  • weinxin
  • 我的微信公众号
  • 我的微信公众号扫一扫
  • weinxin
王世权
  • 本文由 发表于 2015年8月13日 09:48:28
  • 转载请务必保留本文链接:http://www.liaodestudio.com/?p=1009