1.实现销售合同中【直接客户】信息的录入后,自动带出关联【省份】的信息,根据BOS单据的基本设置不能将省份信息写成字

段进行推送,故需要在BOS单据中进行插件开发;

开发过程中有个关键表:

1)选择直接用户的表结构  为新增添的核算项目,查询表语句为:

select b.fid from t_Item_3030 a inner join t_submessage b on a.f_102=b.finterid where a.fitemid = 196918

--t_Item_3030 :核算项目存储表;--t_submessage 辅助资料基础表

2)选择购货客户的表结构,查询语句为:

select B.fid from t_Organization a inner join t_submessage b on a.F_107=b.finterid where fitemid=12316

--客户信息表为:t_Organization; --t_submessage 辅助资料基础表

2.利用K3 wise与VB6.0插件开发工具进行插件开发;开发代码如下:

'定义 BillEvent 接口. 必须具有的声明, 以此来获得事件
Private WithEvents m_BillInterface As BillEvent Public Sub Show(ByVal oBillInterface As Object) 'BillEvent 接口实现
'注意: 此方法必须存在, 请勿修改
Set m_BillInterface = oBillInterface End Sub Private Sub Class_Terminate() '释放接口对象
'注意: 此方法必须存在, 请勿修改
Set m_BillInterface = Nothing End Sub Private Sub m_BillInterface_Change(ByVal Dct As KFO.IDictionary, ByVal dctFld As KFO.IDictionary, ByVal Col As Long, ByVal Row As Long, Cancel As Boolean) 'TODO: 请在此处添加代码响应事件 On Error GoTo Handle Dim LDct As KFO.Dictionary
Dim LdctFld As KFO.Dictionary
Dim LCol As Long, LRow As Long, Fieldname As String
Dim FItemID As Long
Dim SQL(2) As String
Dim obj As Object
Set LDct = Dct
Set LdctFld = dctFld
LCol = Col
LRow = Row
FItemID = Val(LdctFld("FFld")) ''直接用户
If LDct("ctlindex") = 42 And FItemID > 0 Then
SQL(0) = "select b.fid from t_Item_3030 a inner join t_submessage b on a.f_102=b.finterid where a.fitemid = "
SQL(0) = SQL(0) & FItemID
Set obj = m_BillInterface.K3Lib.GetData(SQL(0))
If obj.bof = True Then
Exit Sub
Else
m_BillInterface.SetFieldValue "FBase3", obj!FID
Set obj = Nothing
End If ''购货单位
ElseIf LDct("ctlindex") = 46 And FItemID > 0 Then
SQL(1) = "select b.FID from t_Organization a inner join t_submessage b on a.F_107=b.finterid where fitemid= " & FItemID
Set obj = m_BillInterface.K3Lib.GetData(SQL(1))
If obj.bof = True Then
Exit Sub
Else
m_BillInterface.SetFieldValue "FBase5", obj!FID
Set obj = Nothing
End If ElseIf UCase(LDct("ffieldname")) = UCase("FProductID") And FItemID > 0 Then
''产品代码-包装类别、物料大类
SQL(2) = "select b.fname MatrType,c.fname PackType from t_icitem a inner join t_item b on a.F_128=b.fitemid inner join t_item c on a.F_142=c.fitemid where a.fitemid= "
SQL(2) = SQL(2) & FItemID
Set obj = m_BillInterface.K3Lib.GetData(SQL(2))
If obj.bof = True Then
Exit Sub
Else
m_BillInterface.SetFieldValue "PackType", obj!PackType
m_BillInterface.SetFieldValue "MatrType", obj!MatrType
Set obj = Nothing
End If
End If
Exit Sub
Handle:
MsgBox Error.Description
Set obj = Nothing End Sub

  

程序中出现个人问题,导致时间浪费,主要问题归纳总结为:

On Error GoTo Handle 使用问题 错误处理程序必须在程序结束后,挂上后程序执行未出现错误就不会报错,本次因对该方法运用不熟练导致调试过程中浪费时间较长,后续将on error goto 进行总结;

On Error GoTo

On Error GoTo 0
      表示禁止当前过程中任何已启动的错误处理程序。

On Error Resume Next
     说明当一个运行时错误发生时,控件转到紧接着发生错误的语句之后的语句,并在此继续运行。访问对象时要使用这种形式而不使用 On Error GoTo。

On Error GoTo line
     启动错误处理程序,且该例程从必要的 line 参数中指定的 line 开始。line 参数可以是任何行标签或行号。如果发生一个运行时错误,则控件会跳到 line,激活错误处理程序。指定的 line 必须在一个过程中,这个过程与 On Error 语句相同; 否则会发生编译时间错误。

一般情况下,如果在对我们创建的对象或控件进行错误捕捉,需要使用On Error Resume Next ,然后在判断它的Err.Number,根据错误类型来做相应的处理。

K3 销售合同开发的更多相关文章

  1. K3 WISE 开发插件《K3 WISE常用数据表整理》

    在后台数据库ICClassType表中,字段FID<0的是老单,FID>0的是新单. ----------------系统设置------------------------ FStatu ...

  2. k3 Bos开发百问百答

              K/3 BOS开发百问百答   (版本:V1.1)           K3产品市场部       目录 一.基础资料篇__ 1 [摘要]bos基础资料的显示问题_ 1 [摘要]单 ...

  3. 一、K3 WISE 开发插件《K3 WISE常用数据表整理》

    在后台数据库ICClassType表中,字段FID<0的是老单,FID>0的是新单. ----------------系统设置------------------------FStatus ...

  4. 三、K3 Cloud 开发插件《K3 Cloud插件开发新手指导 + K3 Cloud插件开发代码调试》

    案例需求:在销售订单上新增一个按钮,在订单明细中新增一个字段,命名[即时库存]. 点击按钮,弹出“Hello World!”,并获取订单明细物料的即时库存,填入字段[即时库存]. 开发工具:Visua ...

  5. 六、K3 WISE 开发插件《直接SQL报表开发新手指导 - BOM成本报表》

    ======================== 目录: 1.直接SQL报表 ======================== 1.直接SQL报表 以BOM成本报表为例,在销售模块部署,需要购买[金蝶 ...

  6. 四、K3 WISE 开发插件《工业单据老单插件开发新手指导》

    开发环境:K/3 Wise 13.0.K/3 Bos开发平台.Visual Basic 6.0 =============================================== 目录 一 ...

  7. 十一、K3 WISE 开发插件《VB插件开发如何代码调试 - 步骤讲解》

    =================================== 目录: 1.配置代码调试启动程序kdmain.exe 2.设置断点 3.触发调试 4.变量跟踪 ================ ...

  8. 十、K3 WISE 开发插件《SQL Profiler跟踪单据操作时产生的SQL语句》

    =================================== 目录: 1.查询帐套的数据库DBID 2.配置需要跟踪数据库的DBID 3.配置跟踪参数 4.跟踪进行 5.分析跟踪语句 === ...

  9. 八、K3 WISE 开发插件《工业单据老单插件中获取登陆用户名》

    备注:如果是BOS新单,都有获取用户名的方法.在单据有m_BillInterface.K3Lib.User.UserId,在序时薄有m_ListInterface.K3Lib.User.UserID ...

随机推荐

  1. EurekaLog是什么鬼?

    D的all工程文件打开后,莫名其妙就处于等待打开状态.因为最后一次调整是安装了RO9.0.所以一直怀疑是RO的原因.再加上win7授权问题,安装RO一直不顺当.所以折腾的时间最多. 其他把RO全部卸载 ...

  2. SBC37x交叉编译平台QT+OPENCV【1】

    在win7下安装Vbox虚拟机,然后安装Ubuntu10.04版本.上一篇说了根据厂商提供的编译器进行安装. 接下来要说的的环境准备.因为在Linux下对u盘的识别以及目录的共享,还有代码的编译传送运 ...

  3. 怎么样调整FreeBSD时区问题

    一般我们在安装系统的时候,都会遇到服务器时间不同步的情况.所以必须得设置为中国时区,比较简单的方法,就总结如下几点: 1.通过命令行启动图形界面更改 #sysinstall 请选择 configure ...

  4. 0709关于mysql优化思路【何登成】

    转自 http://isky000.com/database/mysql-performance-tuning-sql 优化目标 减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所 ...

  5. Thread和ThreadGroup

    Thread和ThreadGroup 学习了:https://www.cnblogs.com/yiwangzhibujian/p/6212104.html  这个里面有Thread的基本内容: htt ...

  6. 拒绝switch,程序加速之函数指针数组

    先看一个使用switch语句的程序: #include <stdio.h> #include <time.h> //加法 int add(int a,int b) { retu ...

  7. 并查集图冲突hdu1272

    还是属于并查集的变形 两个点仅仅有一条路径连通 给出的两个点事先都是属于两个集合的 须要给出的着条边构成一个集合 算法复杂度还是挺高的 每一个我都循环了100000次 set2数组没清空 wrong了 ...

  8. 编程基础知识——C++能不能支持Java和ObjC的反射?

    C++能不能支持Java和ObjC的反射? 要回答这个问题.首先我们要清楚什么是反射.什么是反射? 教科书的解释我就不说了,(^o^)事实上我也记不得.实际开发应用的反射就是在没有某个类型的头文件或者 ...

  9. vs2015+ffmpeg开发环境配置【转】

    本文转载自:http://blog.csdn.net/hustlx/article/details/51014307 1.在http://ffmpeg.zeranoe.com/builds/ 下载最新 ...

  10. 【NOIP2011 Day 1】选择客栈

    [问题描述] 丽江河边有n家客栈,客栈按照其位置顺序从1到n编号.每家客栈都按照某一种色调进行装饰(总共k种,用整数0 ~ k-1表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费.两位 ...