Foxtable(狐表)用户栏目专家坐堂 → 代码失效,如何解决?


  共有1895人关注过本帖树形打印复制链接

主题:代码失效,如何解决?

帅哥哟,离线,有人找我吗?
lin98
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1360 积分:9034 威望:0 精华:0 注册:2020/11/4 22:15:00
代码失效,如何解决?  发帖心情 Post By:2024/7/26 9:26:00 [只看该作者]

http://foxtable.com/bbs/dispbbs.asp?boardid=2&Id=145239,看4楼实例
Select e.DataCol.Name
    Case "日期"
        If e.DataRow.IsNull("日期") Then
            e.DataRow("编号") = Nothing
        Else
            Dim dr As DataRow = DataTables("号表").Find("编号 is not null and 表名='订单'", "编号")
            If dr IsNot Nothing Then
                e.DataRow("编号") = dr("编号")
                dr.Delete
DataTables("号表").save
            Else
Dim rt As String = QQClient.SendWait(":f" & e.DataTable.Name & "f:")
                e.DataRow("编号") = rt
             End If
        End If

  Case "编号"
        If e.NewValue Is Nothing AndAlso e.OldValue IsNot Nothing Then 
            Dim dr1 As DataRow = DataTables("号表").Find("表名 ='订单' and 编号 ='" & e.OldValue & "'")
            If dr1 Is Nothing Then
                dr1 = DataTables("号表").AddNew
                dr1("表名") = "订单" 
                dr1("编号") = e.OldValue
                dr1.save
            End If
        End If 
End Select

问题一:日期列的值的改变,没触编号列生成编号的值?
问题二:红代码,没报错,也没执行,无法实现回收使用





的编号,如果有旧编号用旧编号,没旧编号,新生成编号,跨月,旧编号不能用,只能新编号

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110741 积分:563631 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/7/26 9:36:00 [只看该作者]

请上传实例测试

 回到顶部
客人(27.154.*.*)
  3楼


  发帖心情 Post By:2024/7/26 10:04:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:新建文件夹 (4).zip


 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110741 积分:563631 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/7/26 10:10:00 [只看该作者]

测试没有问题,输入日期列就有编号

 回到顶部
帅哥哟,离线,有人找我吗?
lin98
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1360 积分:9034 威望:0 精华:0 注册:2020/11/4 22:15:00
  发帖心情 Post By:2024/7/26 10:34:00 [只看该作者]

问题1:我浿试需要单击编号,才生成,后续会在窗口上文本框来显示,每次操作,都要单击编号,那很不友好
问题2:旧编号没有回收再利用。
[此贴子已经被作者于2024/7/26 10:36:11编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110741 积分:563631 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/7/26 10:42:00 [只看该作者]

1、我测试只需要输入日期,不需要单击什么编号
2、测试没有问题

 回到顶部
帅哥哟,离线,有人找我吗?
lin98
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1360 积分:9034 威望:0 精华:0 注册:2020/11/4 22:15:00
  发帖心情 Post By:2024/7/26 10:51:00 [只看该作者]


图片点击可在新窗口打开查看此主题相关图片如下:qq77.png
图片点击可在新窗口打开查看

 回到顶部
帅哥,在线噢!
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110741 积分:563631 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/7/26 10:54:00 [只看该作者]

没有表名,不知道这个编号是哪个表的

 回到顶部
帅哥哟,离线,有人找我吗?
lin98
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1360 积分:9034 威望:0 精华:0 注册:2020/11/4 22:15:00
  发帖心情 Post By:2024/7/26 14:05:00 [只看该作者]

Dim db = HySq-l.DataBaseFactory.CreateDatabase("编号用户测试库")

'不重复编号上传用,这里的用法比较简单,没有做复杂的编号规则处理'
Public Class BizCodeBuilder
    Private _bizcode As DataTable '直接把编号表取出到内存'
    Private _codelock As New Object
    
    Public Sub New(sjy As String)
        Dim Sql = "selec-t * from {uSysBizCode}" '执行SQL
        Dim dt As system.data.DataTable = db.ExecuteDataSet(Sq-l).Tables(0)
        dt.TableName = "uSysBizCode"
        
        _bizcode = Functions.Execute("Cmd_GetDataTable", sjy, sq-l, True)
    End Sub
    
    Public Function GetNextCode(s_name As String,Optional s_prefix As String = Nothing) As String
        SyncLock _codelock '使用锁处理并发
        Dim dr As DataRow = _bizcode.Find(CExp("BizName='{0}'", s_name))
        If dr Is Nothing Then
            '建议先在编号表中维护好需要产生编号的表,不用默认生成的编号规则'
            dr = _bizcode.AddNew()
            dr("BizName") = s_name 
            dr("MaxValue") = 1
            If String.IsNullOrEmpty(s_prefix) Then s_prefix = Date.now.ToString("mmss") & "BH"
            dr("Prefix") = s_prefix
            dr("Mark") = "yyyyMMdd"
            dr("MarkValue") = Date.Today.ToString("yyyyMMdd")
            dr("Length") = 4
        Else
            '这里的处理规则是按时间进行重新编号,至于是按年,月还是日,在掩码中体现'
            If dr("MarkValue") <> Date.Today.ToString(dr("Mark")) Then 
                dr("MaxValue") = 1
                dr("MarkValue") = Date.Today.ToString(dr("Mark"))
            Else
                dr("MaxValue") = dr("MaxValue") + 1
            End If
        End If
        dr.Save()
        Return dr("Prefix") & dr("MarkValue") & Format(dr("MaxValue"),"0000") '顺序号只取4位'
        End SyncLock
    End Function
End Class

 回到顶部
帅哥哟,离线,有人找我吗?
lin98
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1360 积分:9034 威望:0 精华:0 注册:2020/11/4 22:15:00
  发帖心情 Post By:2024/7/26 14:08:00 [只看该作者]

上面代码报错:

.NET Framework 版本:4.0.30319.42000
Foxtable 版本:2022.8.18.1
错误所在事件:项目,AfterOpenProject
详细错误信息:
FROM 子句语法错误。



'AfterOpenProject里的代码
_BizCodeBuilder = New BizCodeBuilder("")

Forms("窗口1").open


如何解决?

    

 回到顶部
总数 26 1 2 3 下一页