以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.com/bbs/index.asp)
--  专家坐堂  (http://foxtable.com/bbs/list.asp?boardid=2)
----  编码出错,这是什么原因造成的  (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=122915)

--  作者:luodan
--  发布时间:2018/8/4 14:26:00
--  编码出错,这是什么原因造成的
图片点击可在新窗口打开查看图片点击可在新窗口打开查看.NET Framework 版本:2.0.50727.5485
Foxtable 版本:2018.7.28.1
错误所在事件:表,销售订单,DataColChanged
详细错误信息:
调用的目标发生了异常。
表达式包含无效的字符串常量: \' And   下单日期 >= #2018-08-01# And   下单日期 <= #2018-08-31# And [_Identify] <> 5。





--  作者:luodan
--  发布时间:2018/8/4 14:27:00
--  
Select e.DataCol.Name
    Case  "下单日期","单据类型"
        If e.DataRow.IsNull("下单日期") OrElse e.DataRow.IsNull("单据类型") Then
            e.DataRow("订单号") = Nothing
        Else
            Dim  d As Date = e.DataRow("下单日期")
             Dim y As Integer = d.Year
              Dim m As Integer = d.Month
            Dim  Days As  Integer = Date.DaysInMonth(y,m)
             Dim fd As Date = New Date(y,m,1)  \'获得该月的第一天
            Dim ld As Date = New Date(y,m,Days)  \'获得该月的最后一天
            Dim bh As String = e.DataRow("单据类型") & "-" & Format(d,"yyyyMM") & "-"  \'生成编号的前缀
            If e.DataRow("订单号").StartsWith(bh) = False  \'如果订单号前缀不符
                Dim  max As String
                Dim idx As Integer
                Dim flt As String
                flt =  "单据类型 = \'"& e.DataRow("单据类型") &  "\' And   下单日期 >= #" & fd &  "# And   下单日期 <= #" & ld & "# And [_Identify] <> " & e.DataRow("_Identify")
                 max =  e.DataTable.Compute("Max(订单号)",flt)  \'取得该月的相同单据类型的最大订单号
                If max > "" Then  \'如果存在最大订单号
                    idx = CInt(max.Substring(10,4)) + 1  \'获得最大订单号的后四位顺序号,并加1
                 Else
                    idx = 1  \'否则顺序号等于1
                   End If
                e.DataRow("订单号") = bh & Format(idx,"0000")
             End If
        End  If
 End  Select

--  作者:有点蓝
--  发布时间:2018/8/4 14:33:00
--  
如果是SqlServer数据库,把#号改为单引号
--  作者:luodan
--  发布时间:2018/8/4 14:40:00
--  
就是内部数据库
不是SqlServer数据库

--  作者:有点蓝
--  发布时间:2018/8/4 15:00:00
--  
e.DataRow("单据类型")存储的是什么数据?有特殊符号?