动态SQL中DESCRIPTOR的应用

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

动态 SQL中DESCRIPTOR的应用

王光红

动态 SQL具有的灵活性是众所周知的,本人在此介绍一种应用DESCRIPTOR的 动态 SQL

$shortb_num;
$char*command;

$char SQL[1024];
$shortflag;
$dateDate;
$longNumber,b_count,j;
$longprec;
$longtype;
$longscale;
$doublemoney;


sprintf( SQL,"select*fromtable");

$prepareqidfrom$ SQL;
if( SQLCODE)return-1;
$declareBROWSEscrollcursorforqid;
if( SQLCODE)return-2;
$allocatedescriptor'browsdesc'withmax:b_num; //在描述区分配空间,并设置最大的项目数


 $getdescriptor'browsdesc':b_count=count;//得到查询的字段个数
 if( SQLCODE){
   SQLErrHandle( SQLCODE,SELECT);
  gotoEXIT0;
  }

 $fetchBROWSEusing SQLdescriptor'browsdesc';
 if( SQLCODE){
  strcpy(RetPacket.data,"SELECTERROR|");
   SQLErrHandle( SQLCODE,SELECT);
  gotoEXIT0;
  }

 for(j=1;j<=b_count;j++){
  $getdescriptor'browsdesc'value$j  //当前字段序号
  $prec=precision, /*money、decimal*/
  $scale=scale,  /*money、decimal*/
  $type=type;
  if( SQLCODE){
    SQLErrHandle( SQLCODE,SELECT);
   gotoEXIT0;
   }
  switch(type){
  case SQLFLOAT:
  case SQLSMFLOAT:
  case SQLDECIMAL:
  case SQLMONEY:
   if(prec)
   sprintf(fmt,"%s%d.%df/0","%",prec+1,scale);
   else
   strcpy(fmt,"%f");
   $getdescriptor'browsdesc'value$j
    $money=data;
   sprintf(result,fmt,money);

   if( SQLCODE==DATAISNULL)result[0]=0;
   break;
  default:
   $getdescriptor'browsdesc'value$j
    $result=data;
   }//switch

  if( SQLCODE==DATAISNULL) SQLCODE=0;

  if( SQLCODE){
    SQLErrHandle( SQLCODE,SELECT);
   gotoEXIT0;
   }

  OutPut(result);//输出结果

  }//for
<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值