首页 > 数据库技术 > 详细

esql开发总结

时间:2017-05-24 20:41:28      阅读:358      评论:0      收藏:0      [点我收藏+]

1 定义或者声明方法
int method(char *arg1,char* arg2...);
  实现方法
int method(char *arg1,char* arg2...)
    EXEC SQL BEGIN DECLARE SECTION;
        char *arg1;
        char* arg2;
   EXEC SQL END DECLARE SECTION;
 {
    EXEC SQL BEGIN DECLARE SECTION;
    定义自己的变量。仅仅有此处定义的局部变量能够在sql中直接使用。
    EXEC SQL END DECLARE SECTION;
    初始化变量
     memset(sqlbuf,0x00,sizeof(sqlbuf));
     strncpy(from,to);
     deccvdbl(0,&decimal类型变量);
     return 0;
 }
 2 在.h中定义结构体
   如头文件test.h 内容例如以下:
    ...
    EXEC SQL BEGIN DECLARE SECTION;
    typedef struct  LYNAME{
        decimal x ;     
        char y[1+1];
        char z[1+1];       
        int u;
    }x;
    EXEC SQL END DECLARE SECTION;
    ...
    正确引用结构体LYNAME,需使用下边的引入方式
    EXEC SQL include 相对路径/test.h;
    而不是
    #include<test.h>
    
3 经常使用的打印日志方法
  printf("[%s][%d] GetTaxData start\n",__FILE__, __LINE__);
  txlog(LOG_INFO,"current ywrq[%s] =%s\n",__FILE__, __LINE__,x,y);
  #define etxlog(loglevel,format,args...) txlog(loglevel,format,__FILE__,__LINE__,##args);txlogflush()
  #define eetxlog(loglevel,format) txlog(loglevel,format,__FILE__,__LINE__);txlogflush()
  eetxlog(LOG_INFO,"INFO:SSNjbbzlZCZRDZ end.FAILED");
  sprintf(pOutbuf,"FAILED:SELECT NJGRJH.jhbh[%s]qybh[%s]grbh[%s]sqlcode[%d]"
                ,tb_njdl.jhbh,tb_njdl.qybh,val[0],sqlca.sqlcode);
  etxlog(LOG_ERROR,"%s",pOutbuf);
  fprintf(fpLog,"%s|%d|%d|%s|%d|%s\n",strSerial,tb_njdl.clcs,nErrNum++,"数据库错误",nLineCnt,"数据库错误");
 
  4 打印decimal公共方法
 void PrintDecimalToString(ptr_val,desc)
EXEC SQL BEGIN DECLARE SECTION;
        decimal *ptr_val;
        char *desc;
EXEC SQL END DECLARE SECTION;
{
  char decimalResult[30];
  memset(decimalResult,0x00,sizeof(decimalResult));    
  dectoasc(ptr_val,decimalResult,29,8);//将decmail值变成asc码
  txlog(LOG_INFO,"%s = [%s]\n",__FILE__, __LINE__,desc,decimalResult);
  printf("[%s][%d] %s=[%s] \n",__FILE__, __LINE__,desc,decimalResult);
}

esql开发总结

原文:http://www.cnblogs.com/gavanwanggw/p/6900843.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!