标题:INSERT速度太慢
只看楼主
calin
Rank: 2
等 级:论坛游民
帖 子:108
专家分:50
注 册:2010-4-11
结帖率:90.32%
已结贴  问题点数:20 回复次数:9 
INSERT速度太慢
如题,我把EXCEL表用INSERT导入到DBF表。
8万条记录要2个小时,有没有快一点的方法?
搜索更多相关主题的帖子: INSERT 速度 记录 小时 方法 
2017-09-03 09:30
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册:2012-2-5
得分:0 
上传相关文件看看,贴上你的代码

坚守VFP最后的阵地
2017-09-03 10:17
LXHDBCCN
Rank: 2
等 级:论坛游民
帖 子:15
专家分:18
注 册:2013-12-23
得分:10 
我的方法是:
1.将EXCEL文件另存95格式
2.用 APPE FROM 文件名 TYPE XL5
2017-09-04 08:44
厨师王德榜
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:183
帖 子:942
专家分:4724
注 册:2013-2-16
得分:0 
回复 3楼 LXHDBCCN
他说他有8万多条记录,你另存为95格式后,是不是只有65536条记录了?如果记录都丢失了,那你这样做还有什么意义
2017-09-04 10:05
wangzhiyi
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:34
帖 子:366
专家分:684
注 册:2014-4-9
得分:0 
可以考试将EXCEL数据先传到数组里,再添加到DBF文件里吧
2017-09-04 10:07
su0527
Rank: 2
等 级:论坛游民
帖 子:452
专家分:79
注 册:2015-1-10
得分:0 
vfp表操作中记录指针乱回调也会影响录入速度。
2017-09-04 10:42
taifu945
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:80
帖 子:1545
专家分:3298
注 册:2012-7-6
得分:5 
最简单的办法,就是拆成两个60000条以内记录的文件,然后按照3楼的方法做。
2017-09-06 08:49
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:190
帖 子:3125
专家分:8340
注 册:2015-3-25
得分:0 
以下是引用calin在2017-9-3 09:30:46的发言:

如题,我把EXCEL表用INSERT导入到DBF表。
8万条记录要2个小时,有没有快一点的方法?

8W记录,有多个个字段,每个字段的长度大概是什么,类型是什么.
模仿1下,测试对比看看
2017-09-06 08:53
hu9jj
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:红土地
等 级:贵宾
威 望:396
帖 子:11713
专家分:43267
注 册:2006-5-13
得分:5 
拆成多个表逐个导入,减少对系统资源的占用,也会提高速度。

活到老,学到老! http://www. E-mail:hu-jj@
2017-09-06 20:31
红星二锅头
Rank: 8Rank: 8
等 级:贵宾
威 望:46
帖 子:491
专家分:754
注 册:2016-8-25
得分:0 
*!*    从某个大的 Xlsx 文件提取数据的压力测试:
*!*    测试结果:某个 Xlsx 文件有116,000行,12M,SQL 耗时5秒,DBF = 32MB

Clear
Set Talk Off
Local lcXLBook As String, lnSQLHand As Integer, ;
    lcSQLCmd As String, lnSuccess As Integer, ;
    lcConnstr As String
Clear

lcXLBook = Getfile("xlsx")
lnSec = Seconds( )

lcConnstr = [Driver=] + ;
    [{Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)};] + ;
    [DBQ=] + lcXLBook

If !File( lcXLBook )
    ? [Excel 文件没找到]
    Return .F.
Endif
lnSQLHand = SqlStringConnect( lcConnstr )

lcSQLCmd = [Select * From "Sheet$"]  && Sheet Name in Excel
lnSuccess = SQLExec( lnSQLHand, lcSQLCmd, [xlResults] )
? [SQL 命令状态:], Iif( lnSuccess > 0, '成功!', '失败!' )
If lnSuccess < 0
    Local Array laErr[1]
    Aerror( laErr )
    ? laErr(3)
    SQLDisconnect( lnSQLHand )
    Return .F.
Endif

? "耗时:" + TRANSFORM( Seconds( ) - lnSec )
Select xlResults
Browse Normal
SQLDisconnect( lnSQLHand )

团队红星二锅头,队长王猛,领队李冲,顾问杨伟,副队张挺,外联马彪,内勤韩秀,人事顾闯,财务赵魁,后勤周强
2017-09-07 19:19



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-480446-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.047482 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved