以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  遍历选中行新增数据,如何提高增加速度?  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=178041)

--  作者:狐表(小白)
--  发布时间:2022/6/15 17:53:00
--  遍历选中行新增数据,如何提高增加速度?
用附件的代码方式新增选中行,1W行左右的数据要用到20分钟,如何提效?
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:新建文本文档.txt


[此贴子已经被作者于2022/6/15 17:53:25编辑过]

--  作者:有点蓝
--  发布时间:2022/6/16 8:31:00
--  
不要添加一行就保存一行,最后统一保存

If Select_List.count>0 Then
     For Each dr As Row In Select_list
        Dim r As Row=Tables(eform.name & "_Table1").AddNew
        For Each c As Col In r.Table.Cols
            If dr.Table.Cols.contains(c.name) Then
                r(c.name)=dr(c.name)
            End If
        Next
    Next
Tables(eform.name & "_Table1").save
Else

--  作者:狐表(小白)
--  发布时间:2022/6/16 14:37:00
--  
效果还是不是很理想,1W大概需要10分钟
--  作者:有点蓝
--  发布时间:2022/6/16 14:57:00
--  
如果是远程数据库,也差不多这种效果了。

如果是SqlServer,可以考虑:http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=147288&replyID=&skin=1

--  作者:狐表(小白)
--  发布时间:2022/6/16 16:36:00
--  
谢谢老师!遍历选中行后,我用下面的方式直接插入到数据库表中,效果不错,几秒钟搞定!
Dim cmd As new SQLCommand
cmd
.ConnectionName = "数据源名称"
cmd
.CommandText = "Insert Into 订单 (客户, 日期, 订单编号) Values(?,?,?)"
cmd
.Parameters.Add("@客户","01")
cmd
.Parameters.Add("@日期",Date.Today)
cmd
.Parameters.Add("@订单编号",100)
cmd
.ExecuteNonQuery