Statement

在访问外部数据库(非Axapta数据库)的时候,要用到Connection和Statement以及ResultSet三个对象,要注意的是Statement和ResultSet这个对象,如果不认真读Axapta的帮助文档,按照以前的编程习惯可能会出些麻烦.看下面这段代码:
None.gif  Connection con;
None.gif    ResultSet rs;
None.gif    ResultSet rsDetail;
None.gif    Statement stat;
None.gif   
None.gif
None.gif    ;
None.gif    con 
=   new  Connection();
None.gif    stat 
=  con.createStatement();
None.gif   
None.gif    rs 
=  stat.executeQuery(strFmt( " select * from basicdata.dbo.LedgerTable where dataAreaId = '%1' " , " ZB " ));
None.gif    
while (rs.next())
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        info(rs.getString(
1));
InBlock.gif        rsCredit 
= stat.executeQuery(strFmt("select * from basicdata.dbo.LedgerTable where dataAreaId = '%1'","ZB"));
InBlock.gif        
while(rsCredit.next())
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            info( 
"第二次循环:"+rsCredit.getString(1));
ExpandedSubBlockEnd.gif        }

ExpandedBlockEnd.gif    }

按照ADO.NET编程习惯,应该rs和rsCredit分别循环,对应rs中的每一条记录,输出一遍rsCredit中的记录 .
但实际情况是不管rs有多少条记录,第一个循环只会执行一次.看了Statement的帮助文档才知道,每个Statement对象只能对应一个ResultSet,在返回下一个ResultSet时会将上一个关掉,真是奇怪,执行一条语句就返回一个结果集,干吗非要把上一个关掉......
解决办法就是如果ResultSet要嵌套,则用两个Statement分别对应不同的ResultSet,有些bt.
None.gif  Connection con;
None.gif    ResultSet rs;
None.gif    ResultSet rsDetail;
None.gif    Statement stat;
None.gif    Statement statCredit;
None.gif
None.gif    ;
None.gif    con 
=   new  Connection();
None.gif    stat 
=  con.createStatement();
None.gif    statCredit 
=  con.createStatement()
None.gif    rs 
=  stat.executeQuery(strFmt( " select * from basicdata.dbo.LedgerTable where dataAreaId = '%1' " , " ZB " ));
None.gif    
while (rs.next())
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        info(rs.getString(
1));
InBlock.gif        rsCredit 
= statCredit .executeQuery(strFmt("select * from basicdata.dbo.LedgerTable where dataAreaId = '%1'","ZB"));
InBlock.gif        
while(rsCredit.next())
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            info( 
"第二重循环:"+rsCredit.getString(1));
ExpandedSubBlockEnd.gif        }

ExpandedBlockEnd.gif    }

转载于:https://www.cnblogs.com/Farseer1215/archive/2006/12/07/585547.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值