免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: tigerfish
打印 上一主题 下一主题

[求助]如何以最快的速度插入数据? [复制链接]

论坛徽章:
0
11 [报告]
发表于 2003-07-10 13:35 |只看该作者
你这样插入的语句岂不是一点意义都没有?

论坛徽章:
0
12 [报告]
发表于 2003-07-10 13:39 |只看该作者
如果你只要一万多笔没有任何意义的记录,那么可以用如下的T-SQL搞定(假设testtable为空表):
declare @i int
set @i = 14
INSERT INTO testtable (col1, col2,col3) VALUES (\'\'00:00:00\'\', 12345678.901, newid())
while (@i>0)
begin
        insert into testtable(col1,col2,col3)
        select col1,col2,newid() from testtable
        set @i = @i - 1
end

上面的T-SQL语句在你的机器上执行肯定少于10秒

论坛徽章:
0
13 [报告]
发表于 2003-07-10 13:42 |只看该作者
最初由 itsyh 发布
[B]BCP是否要把数据写到TXT文件中,然后把TXT文件导入到数据库中么?这招不错哦!
但是不知道如何通过程序来控制? [/B]


程序是可以写,但是一点意义没有。
先写txt文件,然后再用bcp将文件导入数据库不比直接写数据库慢得多?![/COLOR]

论坛徽章:
0
14 [报告]
发表于 2003-07-10 13:43 |只看该作者
方式不限,但必须是可以控制的,也就是说要插入的列的值是由程序算出来的,然后要把结果集插入到数据库中。
可以通过编程控制,也可以把结果存为SQL脚本文件来执行。。。

目的就是要以最快的速度把结果插入到数据库中。

表结构有点像电话详细通话记录,会有大量数据需要不断更新到数据库中。


如果是这样,可以先生成一些数据文件,当数据批量生成后,再导到数据库中,比如一个小时导一次,一次导10000 或者更多的数据


关键看楼主是要达到什么应用目的  如果是纯粹的测试,也许没什么意思

论坛徽章:
0
15 [报告]
发表于 2003-07-10 14:18 |只看该作者
关键看楼主是要达到什么应用目的 如果是纯粹的测试,也许没什么意思
——肯定不是测试玩的了,我现在要实时采集数据,数据量越大,计算结果也越准确,
所以,希望能够以最快的速度把采集到的数据插入到数据库中,多谢!

我这个测试程序只是为了测试出到底能最多保存多少数据:)所以,跳过了
计算过程。

论坛徽章:
0
16 [报告]
发表于 2003-07-10 14:23 |只看该作者
最初由 zhuzhichao 发布
[B]

程序是可以写,但是一点意义没有。
先写txt文件,然后再用bcp将文件导入数据库不比直接写数据库慢得多?![/COLOR] [/B]


不一定吧?我通过ms sql的数据恢复功能,能够在90秒恢复
100万条这样的TXT格式数据(40M这么大),按照这个速度,我只需要一秒钟就能把一万条数据保存为txt,花一秒钟来存到数据库钟,那简直是梦幻组合啊,呵呵,速度简直快到令人无法相信啊。

论坛徽章:
0
17 [报告]
发表于 2003-07-10 14:30 |只看该作者
最初由 zhuzhichao 发布
[B]如果你只要一万多笔没有任何意义的记录,那么可以用如下的T-SQL搞定(假设testtable为空表):
declare @i int
set @i = 14
INSERT INTO testtable (col1, col2,col3) VALUES (\'\'00:00:00\'\', 12345678.901, newid())
while (@i>0)
begin
        insert into testtable(col1,col2,col3)
        select col1,col2,newid() from testtable
        set @i = @i - 1
end

上面的T-SQL语句在你的机器上执行肯定少于10秒 [/B]


偶不懂您的程序放在那里执行啊?抱歉,我对ms sql了解实在
有限,在Google也没能找到相关的方法,能劳烦你所说么?
通过什么方法来执行上面这个T-SQL啊?

论坛徽章:
0
18 [报告]
发表于 2003-07-10 15:23 |只看该作者
itsyh,如果你能用delphi在一秒钟之内在一个txt文件中写入一万笔记录,那么我立即拜你为师,毫无虚言!
要知道用C也无法达到这样的效率。

我写的那段代码可以做为一个存储过程由你的delphi程序来调用,
也可以在MSSQL的Query Analyzer中直接执行,
也可以用程序直接执行(以字符串的方式,如果delphi的执行SQL如Java一样的话)

论坛徽章:
0
19 [报告]
发表于 2003-07-10 16:15 |只看该作者
如果这样,你先做数据保存到 txt 文件,再批量提交
这样,你能够保存的数据量就不受到数据库的限制
你能够采集多快,数据就能够保存多少

这样应该是最快的

论坛徽章:
0
20 [报告]
发表于 2003-07-10 17:04 |只看该作者
能够直接写数据库,
为何还要先IO文件,然后再从文件导入?
一步做到的事情分成两步做岂不是耗费时间?

写IO的时间不一定比写数据库的时间少!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP