免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3447 | 回复: 8
打印 上一主题 下一主题

DBI::st??? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-04-14 13:50 |只看该作者 |倒序浏览
要实现的功能如下:从数据库中取值,最多一次取5个。
数据库中数据是否为空,等待5秒钟后程序重新启动从数据库取值。

代码如下:
.........
my $sql = qq{ SELECT * from cmd limit 5};

my $sth = $db->;prepare( $sql );

if ($sth->;numrows == 0)
        {
         sleep(5);
         next;
        }
$sth->;execute();

为什么报错为:Can't locate object method "numrows" via package "DBI::st" at ./action_00.pl line 29.

我应该怎么修改?

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2003-04-14 18:21 |只看该作者

DBI::st???

你還沒有$sth->;execute;
怎麼就會知道有多少 row???
另外沒有這個numrows的method...
你在去看一下document 查清楚點吧..

论坛徽章:
0
3 [报告]
发表于 2003-04-14 18:39 |只看该作者

DBI::st???

没有这个方法。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
4 [报告]
发表于 2003-04-14 21:28 |只看该作者

DBI::st???

你的問題解法..
use DBI;
&DB_CON;

$sql="SELECT XXXX from table where condition";
Retry:
$sth=$db->;prepare(qq{ $sql })
    || die "Can't prepare $sql: $DBI::errstr";
$sth->;execute || die "can't execute sql: $DBI::errstr";

$n=0;
$flag=0;
while(@row=$sth->;fetchrow_array()){
       $flag=1;
        $n++;
      ## do something with @row
        if($n==5){ last;}
}
# 沒數據的時候
if($flag ==0){
sleep(5);
goto Retry;
}

如果數據一直是空的,上面會是個無窮迴圈沒完沒了...
我沒debug過..你自己debug與加上其他程序碼吧...
雖然很多書上都建議不要用goto..不過goto偶爾
還是有點用處的..

另外你的程序碼中,一定要先fetchrow_array;
你那個類似的numrows的method才會累加..不然都是0....

论坛徽章:
0
5 [报告]
发表于 2003-04-15 16:51 |只看该作者

DBI::st???

谢谢

原帖由 "apile" 发表:
你的問題解法..
use DBI;
&DB_CON;

$sql="SELECT XXXX from table where condition";
Retry:
$sth=$db->;prepare(qq{ $sql })
    || die "Can't prepare $sql: $DBI::errstr";
$sth->;execute || die..........

论坛徽章:
0
6 [报告]
发表于 2003-04-16 11:51 |只看该作者

DBI::st???

你的数据库连接一直保持着? :)

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
7 [报告]
发表于 2003-04-16 12:22 |只看该作者

DBI::st???

程序結束..connection會自動斷掉..所以一般dbi的document..
有提過寫不寫disconnection的code無所謂..perl會自動中斷..

论坛徽章:
0
8 [报告]
发表于 2003-04-16 17:17 |只看该作者

DBI::st???

hi apile  :

我是说他程序设计的问题,不是说你写的代码问题 ;)

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
9 [报告]
发表于 2003-04-16 22:52 |只看该作者

DBI::st???

sorry..不好意思..我誤解了...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP