動態SQL中DESCRIPTOR的應用 (轉)
動態中DESCRIPTOR的應用
王光紅
動態SQL具有的靈活性是眾所周知的,本人在此介紹一種應用DESCRIPTOR的動態SQL:
$short b_num;
$char *command;
$char Sql[1024];
$short flag;
$date Date;
$long Number, b_count, j;
$long prec;
$long type;
$long scale;
$double money;
sprintf(Sql, " * from table");
$prepare qid from $Sql;
if(SQLCODE) return -1;
$declare BROWSE scroll cursor for qid;
if(SQLCODE) return -2;
$allocate descriptor 'browsdesc' with max :b_num; //在描述區分配空間,並設定最大的專案數
$get descriptor 'browsdesc' :b_count=count;//得到查詢的欄位個數
if(SQLCODE){
SqlErrHandle(SQLCODE, SELECT);
goto EXIT0;
}
$fetch BROWSE using sql descriptor 'browsdesc';
if(SQLCODE){
strcpy(RetPacket.data, "SELECT ERROR|");
SqlErrHandle(SQLCODE, SELECT);
goto EXIT0;
}
for(j=1;j<=b_count;j++){
$get descriptor 'browsdesc' value $j //當前欄位序號
$prec=precision, /*money、decimal*/
$scale=scale, /*money、decimal*/
$type=type;
if(SQLCODE){
SqlErrHandle(SQLCODE, SELECT);
goto EXIT0;
}
switch(type){
case SQLFLOAT:
case SQLSMFLOAT:
case SQLDECIMAL:
case SQLMONEY:
if(prec)
sprintf(fmt, "%s%d.%df", "%",prec+1, scale);
else
strcpy(fmt, "%f");
$get descriptor 'browsdesc' value $j
$money=data;
sprintf(result, fmt, money);
if(SQLCODE==DATAISNULL) result[0]=0;
break;
default:
$get descriptor 'browsdesc' value $j
$result=data;
}//switch
if(SQLCODE==DATAISNULL) SQLCODE=0;
if(SQLCODE){
SqlErrHandle(SQLCODE, SELECT);
goto EXIT0;
}
OutPut(result);//輸出結果
}//for
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10748419/viewspace-958672/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 動態SQL應用小列子 (轉)SQL
- SqlServer中的動態SqlSQLServer
- 給你的應用程式新增動態滑鼠 (轉)
- php中的動態變數的一個應用PHP變數
- 動態SQL語句 (轉)SQL
- PL/SQL中動態掉用儲存過程SQL儲存過程
- 用動態SQL語句SQL
- 動態效果在體驗設計中的應用
- SQL 中的統計應用SQL
- PL/SQL開發中動態SQL的使用方法SQL
- 使用CASE表示式替代SQL Server中的動態SQLSQLServer
- 在Web應用中動態建立PDF檔案Web
- 繫結變數在靜態sql和動態sql中變數SQL
- 動態代理的實際應用
- 動態代理的原理及其應用
- 動態record陣列的應用陣列
- SQL 如何實現動態的行列轉置SQL
- Win2000動態DNS的安全應用策略(轉)DNS
- Oracle與SQL Server在企業應用中的比較(轉)OracleSQLServer
- LINUX動態連結庫高階應用(轉)Linux
- oracle動態sql執行table表中儲存的sqlOracleSQL
- PLSQL Language Referenc-PL/SQL動態SQL-動態SQL中重複的佔位符名名稱SQL
- iptables應用之動態DNS(轉)DNS
- sql server中的hash應用優化SQLServer優化
- JavaScript+PHP 應用一:網頁製作中雙下拉選單的動態實現 (轉)JavaScriptPHP網頁
- oracle動態sql語句處理(轉)OracleSQL
- 動態載入!dom應用!
- PLSQL Language Referenc-PL/SQL動態SQL-練習:在動態SQL塊中呼叫子程式。SQL
- 單引號在動態SQL中的處理SQL
- 動態SQLSQL
- 動態SQL intoSQL
- 在hibernate中如何使用動態sqlSQL
- SQL SERVER 中構建執行動態SQL語句SQLServer
- Node應用的Systemd啟動(轉)
- cglib動態代理和jdk動態代理的區別與應用CGLibJDK
- Java動態代理—框架中的應用場景和基本原理Java框架
- Java動態代理——框架中的應用場景和基本原理Java框架
- oracle 繫結變數在動態條件統計中的應用Oracle變數