liumilan2009 发表于 2010-07-16 17:40

程序日志显示入库成功,但是用sql语句找字段却找不到?

用C++程序写了一个入库字段程序。
数据库为informix

日志显示已经成功入库

但是进informix数据库时候,用select * from tfa_alarm_act where a=12;
no data return.
这是什么原因?

程序用ODBC的API写的SQLExecDirect

是程序原因还是数据库原因啊?

照理说若没成功入库,那应该报错才对

liaosnet 发表于 2010-07-16 18:03

这个...

原因也许很多..来几个假设吧.
1,程序问题..压根就没操作成功...review程序设计..
2,数据库问题..也有可能,比如使用了BUFF LOG的数据库,可能BUFFER缓冲区没填满..数据没刷回磁盘...

yunzhongyue 发表于 2010-07-16 21:27

",数据库问题..也有可能,比如使用了BUFF LOG的数据库,可能BUFFER缓冲区没填满..数据没刷回磁盘..."
会有这种可能吗?觉得不可思议!

liaosnet 发表于 2010-07-16 22:33

",数据库问题..也有可能,比如使用了BUFF LOG的数据库,可能BUFFER缓冲区没填满..数据没刷回磁盘..."
会有这 ...
yunzhongyue 发表于 2010-07-16 21:27 http://bbs3.chinaunix.net/images/common/back.gif


看下 BUFFER LOG型的库介绍~:em03:当然出现这样的情况比较少而已..

yunzhongyue 发表于 2010-07-17 10:58

回复 4# liaosnet

难道数据库只会从磁盘上取数据?

liaosnet 发表于 2010-07-17 11:02

本帖最后由 liaosnet 于 2010-07-17 11:03 编辑

回复liaosnet

难道数据库只会从磁盘上取数据?
yunzhongyue 发表于 2010-07-17 10:58 http://bbs3.chinaunix.net/images/common/back.gif


    反正不会从LOGBUF里读数~~:em17:

不过在这种情况下.应该过一会就会提交回磁盘的~就可以查到了..

yunzhongyue 发表于 2010-07-17 11:35

回复 6# liaosnet


    LOGBUF和BUF不是一回事吧,LOGBUF里的东西是要写回逻辑日志当中的。数据库是不会从LOGBUF中读数,但是会在BUFFER中读数啊。

liaosnet 发表于 2010-07-17 16:22

回复liaosnet


    LOGBUF和BUF不是一回事吧,LOGBUF里的东西是要写回逻辑日志当中的。数据库是不会 ...
yunzhongyue 发表于 2010-07-17 11:35 http://bbs3.chinaunix.net/images/common/back.gif


    新插入的数据是到LOGBUF的..不是到BUFFER的撒..BUFFER的数据是从磁盘上读取的..

yunzhongyue 发表于 2010-07-19 14:58

回复 8# liaosnet


    这个还是不太明白,logbuf不是应该刷到逻辑日志当中的吗?
   可否详细说一下或提供一下相关的资料,谢谢!:mrgreen:

yunzhongyue 发表于 2010-07-19 15:12

回复 9# yunzhongyue

做了个试验,insert 一些记录到buf log的数据库中,onstat -p中的bufwrites是会增加的,这个是不是意味着有写buffer呢?
页: [1] 2
查看完整版本: 程序日志显示入库成功,但是用sql语句找字段却找不到?