⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cms657.sqc

📁 一整套完整的银行卡系统源代码
💻 SQC
字号:
/******************************************************************** **   源码文件名称 : cms657.SQC **   函数名称 	   : cms216057 **   所属子系统   : CMS  **   当前文件版本 : 1.0.0.0 **   作        者 : ZhouR  **   版本创建日期 : 2004/10/14 **   功能描述     : 退货通知登记簿打印 **   修改记录     : **   修改人       修改日期     修改日期*********************************************************************/#include    "sysdefine.h"#include    <stdio.h>#include	"pubcom.h"#include	"funcapi.h"#include    "code.h"#include    "attrdef.h"#include    "cmscode.h"#include	"cmsejectnote.h"#include 	"errlog.h"EXEC SQL INCLUDE sqlca;#define 	OVERPAGE	45       /* 满页行数 */ #define 	OVERLINE	5        /* 换行行数 */ #define		LIMIT		50struct	prtdata{	char	acCardNo[CARDNO_LEN +1];			/* 卡号     */	char	acSrvStan[BIT7_LEN + 1];			/* 系统参考号 */	char	acTranDate[DATE_LEN + 1];		 	/* 交易日期 */	char    acSettleDate[DATE_LEN + 1];   		/* 清算日期 */	char	acEjectAmt[BIT18_LEN + 1];			/* 退货金额 */	char  	acDevTDTime[DATE_LEN  + 1];			/* 交易传输时间 */	char 	acAcqIns[BIT12_LEN  + 1];			/* 代理行机构标识 */	char 	acDevID[BIT9_LEN + 1];				/* 设备代码 */	char 	acMid[MID_LEN + 1];					/* 商户代码 */	char 	acCcy[BIT15_LEN + 1];				/* 币种 	*/};#define 	PRTLINE												\	if( prtline( fp, acFmtFile,acPrtData ) ) 					\	FUNCERR_PRO													\	iLineCount++;#define		PRTHEAD 											\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp,"title:%s", acBankname);						\	iLineCount++;												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "title0:%s|%d",								\			 pstPubcom->acBrc, iPage	 );					    \	iLineCount++;												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "head:"	);									\	iLineCount++;												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "body:"	);									\	iLineCount++;#define		PRTBODY												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "body0:%s|%s|%s|%s|%s|%s|%s|%s|%s|%s",  		\			stPrtdata.acCardNo,		stPrtdata.acSrvStan,		\			stPrtdata.acTranDate,	stPrtdata.acSettleDate,		\			stPrtdata.acEjectAmt,   stPrtdata.acDevTDTime,		\			stPrtdata.acAcqIns,		stPrtdata.acDevID,	    	\			stPrtdata.acMid,	 	stPrtdata.acCcy );			\	iLineCount++;												\	iLine	++ ;	#define		PRTFOOT												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "tail1:" );									\	iLineCount++;												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "bottm:%s", 									\			 pstPubcom->acTeller );								\	iLineCount++;												\	memset( acPrtData, 0x00, sizeof( acPrtData ) );				\	prtline( fp, "next:%s",pstPubcom->acTranDate );				\	iLineCount++;												\	iPage	++ ;	iLine	=	0 ;	int cms216057(pstPubcom)struct          pubcom          *pstPubcom;{	EXEC SQL BEGIN DECLARE SECTION;	char    acBeginDate[DATE_LEN + 1 ];      	/* 起始日期 */ 	char    acEndDate[DATE_LEN + 1 ];      		/* 终止日期 */ 	char	acWhrStr[ 512 ];	EXEC SQL END   DECLARE SECTION;	char	acBankname[ 41 ];	char    acCcy[CCY_LEN + 1];                /* 币种 */	FILE	*fp,*fmtfp;							/* 文件指针	*/ 	char    acBuffer[15];	char	acSelStr[ 301 ];	char	acWhrStr1[ 512 ];	char	acWhrStr2[ 512 ];	char	acWhrStr3[ 512 ];	char	acWhrStr4[ 512 ];	char	acWhrStr5[ 512 ];	char	acStr1[ 141 ];	int		iLineCount	=	0 ;	int		i, iPage, iLine ;	char	acFileName[ 101 ];	char	acFmtFile[ 101 ];	char	acPrtData[ 4096 ];	struct	prtdata	stPrtdata;	struct  cmsejectnote      stCmsWnote;     	/* 差错通知登记簿 */	memset( acBeginDate,   0x00, sizeof( acBeginDate ));	memset( acEndDate,     0x00, sizeof( acEndDate )  );  	memset( acBuffer,      0x00, sizeof( acBuffer )   );	memset( acSelStr, 	   0x00, sizeof( acSelStr )   );	memset( acWhrStr, 	   0x00, sizeof( acWhrStr )   );	memset( acWhrStr1, 	   0x00, sizeof( acWhrStr1 )  );	memset( acWhrStr2, 	   0x00, sizeof( acWhrStr2 )  );	memset( acWhrStr3, 	   0x00, sizeof( acWhrStr3 )  );	memset( acWhrStr4, 	   0x00, sizeof( acWhrStr4 )  );	memset( acWhrStr5, 	   0x00, sizeof( acWhrStr5 )  );	memset( acStr1, 	   0x00, sizeof( acStr1 )     );	memset( &stCmsWnote,   0x00, sizeof( struct cmsejectnote ));	memset( acBankname,    0x00, sizeof(acBankname));	if ( pubGetBaseInfo("BANKNAME", acBankname ) )		FUNCERR_PRO	/* 取数据字典 */  	getstring( "BeginDate1", 	acBeginDate );	getstring( "EndDate1", 		acEndDate	);     		sprintf( g_acTrcMsg,"BeginDate1[%s]EndDate1[%s]",						 acBeginDate,acEndDate );  	TRCLOG4	fp = (FILE *)BeginFile( pstPubcom, NULL );	if ( fp == NULL )	{		ERRLOG		return FAILED ;	}	sprintf( acFmtFile, "%s/fmt/cms657.fmt", getenv("HOME") );	sprintf( g_acFmtFile, acFmtFile );          	if( ( fmtfp=fopen(acFmtFile,"r") ) == NULL )	{                                           		strcpy( g_acTrcMsg, acFmtFile );        		TRCLOG2                                 		strcpy( g_acRspCode, "CMS1B0" );		sprintf( g_acRspMsg, "打开格式文件[%s]错", acFmtFile );		ERRLOG		goto Exit;	}	iLine	=	0 ;			iPage	=	1 ;	sprintf( acWhrStr1, " select * from cmsejectnote ");	sprintf( acWhrStr2, "  where 1=1");	if ( strcmp ( acBeginDate, INITDATE ) )	{		sprintf( acWhrStr3, "  and settledate >= '%s'",  acBeginDate );	}	if ( strcmp ( acEndDate, INITDATE ) )	{		sprintf( acWhrStr4, "   and settledate <= '%s'",  acEndDate );	}	sprintf( acWhrStr5, " ORDER BY settledate, cardno, serseqno DESC" );	sprintf( acWhrStr, "%s%s%s%s%s",acWhrStr1,acWhrStr2,acWhrStr3,acWhrStr4,acWhrStr5 ); 	strcpy( g_acTrcMsg, acWhrStr );	TRCLOG4                        	EXEC SQL    PREPARE pre_1 FROM :acWhrStr;	if ( SQLCODE )                      	{                                   		strcpy( g_acRspCode, "CMS1A7" );		pubCrtRspInfo( SQLCODE );       		ERRLOG                          		goto Exit;	}                                   	EXEC SQL    DECLARE wor_l_cur CURSOR FOR pre_1;	if(SQLCODE)	{		sprintf( g_acTrcMsg,"SQLCODE[%d]", SQLCODE);  		TRCLOG4		strcpy( g_acRspCode, "CMS110" );		pubCrtRspInfo("cmsejectnote",SQLCODE );		ERRLOG		goto Exit ;	}	SQLOPENCUR(wor_l_cur,"wor_l_cur")	if(SQLCODE)	{		sprintf( g_acTrcMsg,"SQLCODE[%d]", SQLCODE);  		TRCLOG4		strcpy( g_acRspCode, "CMS111" );		pubCrtRspInfo("cmsejectnote",SQLCODE );		ERRLOG		goto Exit ;	}	for( ; ; )	{		memset( &stPrtdata,	0x00,	sizeof( struct prtdata ) );		pubInitCmsejectnote();		EXEC SQL FETCH wor_l_cur into R_CMSEJECTNOTE;		if( SQLCODE == SQLNOTFOUND )	break ;		sprintf( g_acTrcMsg,"SQLCODE[%d]", SQLCODE);  		TRCLOG4		if(SQLCODE)		{			sprintf( g_acTrcMsg,"SQLCODE[%d]", SQLCODE);  			TRCLOG4			strcpy( g_acRspCode, "CMS112" );			pubCrtRspInfo("cmsejectnote",SQLCODE );			ERRLOG	SQLCLOSECUR(wor_l_cur,"wor_l_cur")			goto Exit ;		}		sprintf( g_acTrcMsg,"SQLCODE[%d]", SQLCODE);  		TRCLOG4		/* 转换币种 */		strcpy ( acCcy, cmsejectnote_ccy );		TransMemo( "0025" , acCcy , acBuffer);		sprintf( g_acTrcMsg,"SQLCODE[%s]", acBuffer  );		TRCLOG4		strpack ( cmsejectnote_devid );		strcpy ( stPrtdata.acCardNo, 		cmsejectnote_cardno );		strcpy ( stPrtdata.acSrvStan,  		cmsejectnote_srvstan  );		strcpy ( stPrtdata.acTranDate, 		cmsejectnote_trandate  );		strcpy ( stPrtdata.acSettleDate,  	cmsejectnote_settledate );		sprintf( stPrtdata.acEjectAmt, 	"%.2lf", 	cmsejectnote_ejectamt );		strcpy ( stPrtdata.acDevTDTime,  	cmsejectnote_devtransdatetime  );		strcpy ( stPrtdata.acAcqIns,  		cmsejectnote_acqins  );		strncpy( stPrtdata.acDevID,   		cmsejectnote_devid, 8 );		strcpy ( stPrtdata.acMid,   		cmsejectnote_mid   );		strcpy ( stPrtdata.acCcy,   		acBuffer   );		sprintf(  g_acTrcMsg, "acCardNo[%s],acSrvStan[%s],acTranDate[%s],"					"acSettleDate[%s],acDevTDTime[%s],acEjectAmt[%s],acAcqIns[%s],"					"acDevID[%s],acMid[%s],acCcy[%s]", 					stPrtdata.acCardNo,   stPrtdata.acSrvStan, stPrtdata.acTranDate,						stPrtdata.acSettleDate, stPrtdata.acDevTDTime, stPrtdata.acEjectAmt,  					stPrtdata.acAcqIns,  stPrtdata.acDevID, 					stPrtdata.acMid, 	  stPrtdata.acCcy );		TRCLOG4				if( iLine	==	0 ) { PRTHEAD }				PRTBODY				if( iLine % OVERPAGE == 0 )				{ PRTFOOT }		sprintf( g_acTrcMsg, "%s|%s|%s|%s|%s|%s|%s|%s|%s|%s",	\				stPrtdata.acCardNo,		stPrtdata.acSrvStan,			\			stPrtdata.acTranDate,	stPrtdata.acSettleDate,			\			stPrtdata.acEjectAmt,   stPrtdata.acDevTDTime,			\			stPrtdata.acAcqIns,		stPrtdata.acDevID,	    		\			stPrtdata.acMid,	 	stPrtdata.acCcy );				\		TRCLOG4	}	SQLCLOSECUR(wor_l_cur,"wor_l_cur")		if( iLine < OVERPAGE && iLine != 0 )	{ PRTFOOT }	if( iLineCount == 0 )	{		strcpy( g_acRspCode, "CMS113" );		sprintf( g_acRspMsg, "无满足条件的纪录!" );		ERRLOG		goto	Exit ;	}	Exit:	fclose( fmtfp );	fclose( fp );	if( !strcmp( g_acRspCode, RSP_OK ) )	{		SetInqFormid(pstPubcom, "") ;		return SUCCESS; 	}	else 		return FAILED ;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -