欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件高级功能研发区 → [求助]如何成功将数据写入数据库?

   

欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。    


  共有10336人关注过本帖平板打印复制链接

主题:[求助]如何成功将数据写入数据库?

帅哥哟,离线,有人找我吗?
wattwei
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:论坛游侠 帖子:574 积分:3167 威望:0 精华:0 注册:2009/10/10 11:13:01
  发帖心情 Post By:2010/8/12 21:20:37 [只看该作者]

有一种办法可以不取过去的数据

加上语句
DATABASE('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\Test.mdb');
DBTABLE2('Select * From RB');
If Not(IsLastBar) Then exit;
DBEXECUTE('insert into RB(stockclose) values('&NUMTOSTR(close,2)&')');


这一语句的意思是只考虑最后一个数据BAR

但是实验下来的效果不理想,即使是最后一个bar,金字塔也要操作多次,估计了下大概2秒钟一次。如果是等时间间隔(需admin确认),这种方法可能可以用来采集些盘口数据。

如果想对应一根K线,仅仅采集一次数据,如何实现,方法如下
1.在数据表中加多个数据项,cnt,设定为索引不重复
2.改写公式DBEXECUTE('insert into RB(cnt,stockclose) values('&NUMTOSTR(barpos-1,0)&','&NUMTOSTR(ref(close,1),5)&')');

利用索引不重复的机理,使每个bar的数据仅写入表一次。注意写入数据要使用ref(...,1),由于当前的bar的数据没有完全形成,只能记录上一根bar的数据


 回到顶部
总数 19 1 2 下一页