Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共8 条记录, 每页显示 10 条, 页签: [1]
[浏览完整版]

标题:表格数据的交互

1楼
puma 发表于:2024/4/15 11:11:00
按钮里有一个复杂的计算过程,如果直接造成程序假死。
如果用异步,不支持
如果用同步,也会出现各种绑定的错误(bing错误)。
如果用sql,需要不停的刷新当前行(不会报错)。

我的需求是,代码需要和table交互。应该用什么解决方法?
2楼
cd_tdh 发表于:2024/4/15 11:13:00
http://www.foxtable.com/webhelp/topics/0624.htm
http://www.foxtable.com/webhelp/topics/0625.htm
不建议高频率刷新,服务器遭不做。
[此贴子已经被作者于2024/4/15 11:13:48编辑过]
3楼
有点蓝 发表于:2024/4/15 11:19:00
请举例说明一下,具体要做什么,用了什么代码,有什么问题
4楼
puma 发表于:2024/4/15 11:33:00
以下是引用cd_tdh在2024/4/15 11:13:00的发言:
http://www.foxtable.com/webhelp/topics/0624.htm
http://www.foxtable.com/webhelp/topics/0625.htm
不建议高频率刷新,服务器遭不做。
[此贴子已经被作者于2024/4/15 11:13:48编辑过]


感谢!现在没有用sql,只是pc与table交互。保存的table的时候,才和服务器交互。

[此贴子已经被作者于2024/4/15 11:33:30编辑过]
5楼
puma 发表于:2024/4/17 16:13:00
这个报错。用的是同步,没有用异步
图片点击可在新窗口打开查看此主题相关图片如下:6c1a36c754d3ef08f4ccc1a70c0b391.jpg
图片点击可在新窗口打开查看
6楼
有点蓝 发表于:2024/4/17 16:30:00
写了什么代码,做了什么操作
7楼
puma 发表于:2024/4/18 9:24:00
通过按钮直接点击没有问题。
通过同步Functions.asyncExecute()  执行报错

代码如下。大概有7-10个这样的按钮,最多修改数据,可以估计有大几十次(语句)


        r("第一列") = regBN(0)
        r("第二列") = regBN(1)
        r("第三列”) = regBN(2)
        r("进度”) = 12




DrawCell事件

If e.Col.Name = "进度" AndAlso e.Row.IsNull("进度") = False Then
    If   e.Row("进度")>0 Then
        e.StartDraw()
        Dim 进度 As Integer= e.Row("进度")
        Dim Width As Integer = (e.Width - 2) * 进度 \ 100
        'Dim Width As Integer = (e.Width - 2) * e.Row("进度") \ 100
        
        'e.Row("进度") = e.Row("进度")
        
        If 进度 = 100 Then
            e.Graphics.FillRectangle(Brushes.Green, e.x + 1, e.y + 1, Width, e.Height - 2)
        Else
            e.Graphics.FillRectangle(Brushes.Red, e.x + 1, e.y + 1, Width, e.Height - 2)
        End If
        e.EndDraw()
    End If
End If


If   e.Col.Name = "状态" Then
    e.StartDraw()
    If e.Row(e.Col.Name) ="重复" Then
        e.Graphics.FillRectangle(Brushes.Red, e.x+1, e.y+1, e.Width-2 , e.Height-2 )
    Else If e.Row(e.Col.Name) ="失败" Then
        e.Graphics.FillRectangle(Brushes.YELLOW, e.x+1, e.y+1, e.Width-2 , e.Height-2 )
    End If
    e.EndDraw()


    'Else
    '
    'e.Graphics.FillRectangle(Brushes.Green, e.x, e.y, e.Width , e.Height )
End If
[此贴子已经被作者于2024/4/18 9:40:26编辑过]
8楼
有点蓝 发表于:2024/4/18 9:40:00
同步函数是给异步函数调用的,如果没有使用异步没有必要使用同步函数。直接调用即可:Functions.Execute()
共8 条记录, 每页显示 10 条, 页签: [1]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .04297 s, 2 queries.