亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? db_op.ec.std

?? 界面庫
?? STD
?? 第 1 頁 / 共 5 頁
字號:
}
#endif

/***************************************************************
功能:
	裝載收單行交易路由信息
ENTRY:
RETURN:
	0	SUCC
	-1	FAIL
****************************************************************/
int load_adv_router_tab ()
{

EXEC SQL BEGIN DECLARE SECTION;
S_adv_route adv_router_item;
EXEC SQL END DECLARE SECTION;

int 	i;
	
	EXEC SQL SELECT COUNT(*) INTO :G_adv_router_num
	FROM adv_route;
	
	if (SQLCODE) {
		errcall(ERROR, "取通知交易路由條目數失敗[%ld]", SQLCODE);
		return -1;
	}
	
	if (G_adv_router_num == 0) {
		errcall(DEBUG, "通知路由沒有配置");	
		return -1;
	}
	
	if (G_adv_router_tab != NULL)
		free(G_adv_router_tab);
	
	G_adv_router_tab = (S_adv_route *)malloc(G_adv_router_num*sizeof(S_adv_route));

	if (G_adv_router_tab == NULL) {
		errcall(ERROR, "申請內存失敗!");
		return -1;
	}

	memset(G_adv_router_tab, '\0', sizeof(S_adv_route) * G_adv_router_num);
	
	
	EXEC SQL DECLARE sel_adv_router CURSOR FOR 
	SELECT * FROM adv_route;

	EXEC SQL OPEN sel_adv_router;
	
	if (SQLCODE) {
		errcall(ERROR, "打開數據庫游標失敗[%ld]!", SQLCODE);
		free(G_adv_router_tab);
		G_adv_router_tab = NULL;
		return -1;
	}
	
	for(i=0; i<G_adv_router_num; i++) {

		EXEC SQL FETCH sel_adv_router INTO :adv_router_item;
		
		if (SQLCODE) {
			EXEC SQL CLOSE sel_adv_router;
			G_adv_router_num = i;
			return 0;
		}
		
		del_st_space("adv_route", &adv_router_item);
		memcpy(&(G_adv_router_tab[i]), &adv_router_item, sizeof(S_adv_route));
	}

	EXEC SQL CLOSE sel_adv_router;
	return 0;
}


/***************************************************************
功能:
	獲取某卡的止付信息
ENTRY:
RETURN:
	0	SUCC 	FOUND
	-1	FAIL
	-2	NOT FOUND
****************************************************************/
int select_hmd ( S_wb_list *hm )
{
EXEC SQL BEGIN DECLARE SECTION;
char		card_no[20];
S_wb_list	l_wb_list;
EXEC SQL END DECLARE SECTION;

	memset(card_no, '\0', sizeof(card_no));
	strcpy (card_no, hm->card_no);

	EXEC SQL SELECT * INTO :l_wb_list FROM wb_list
	WHERE	card_no = :card_no;
	
	if (SQLCODE == SQLNOTFOUND){
		return -2;
	}
	
	if (SQLCODE < 0) {
		errcall(ERROR, "查止付名單失敗[%ld]", SQLCODE);
		return -1;
	}
	
	del_st_space("wb_list", &l_wb_list);
	memcpy(hm, &l_wb_list, sizeof(S_wb_list));
	
	return 0;
}

/***************************************************************
功能:
	根據商戶號到商戶表中查找該商戶的基本信息
ENTRY:
	S_merchant_base	包含該商戶的商戶號
RETURN:
	0	SUCC
	-1	FAIL
	1	NOT FOUND
****************************************************************/
int select_merchant_base ( S_merchant_base *merchant_c )
{
EXEC SQL BEGIN DECLARE SECTION;
char		m_id[16];
S_merchant_base	l_merchant_base;
EXEC SQL END DECLARE SECTION;

	memset(m_id, '\0', sizeof(m_id));
	strcpy(m_id, merchant_c->merchant_id);
	
	EXEC SQL SELECT * INTO :l_merchant_base FROM merchant_base
	WHERE merchant_id = :m_id;
	
	if (SQLCODE == SQLNOTFOUND) {
		return -2;
	}
	
	if (SQLCODE < 0) {
		errcall(ERROR, "取商戶基本信息失敗[%ld]", SQLCODE);
		return -1;
	}
	
	del_st_space("merchant_base", &G_merchant_base);
	memcpy(merchant_c, &l_merchant_base, sizeof(S_merchant_base));
	
	return 0;
}
 
/***************************************************************
功能:
	根據商戶號, 銀行類型, 卡類型到商戶受理卡類表中查找該商戶
	的他行商戶編號以及商戶類型
ENTRY:
	S_merchant_card	包含該商戶的商戶號和商戶受理卡類型
			信息的受理卡類表
RETURN:
	0	SUCC 	受理卡類表信息==>S_merchant_card
	-1	FAIL 
	-2	NOT FOUND
****************************************************************/

int select_merchant_card( S_merchant_card *merchant_card )
{
EXEC SQL BEGIN DECLARE SECTION;
S_merchant_card	merch_card;
EXEC SQL END DECLARE SECTION;

	memcpy(&merch_card, merchant_card, sizeof(S_merchant_card));

	EXEC SQL SELECT * INTO :merch_card FROM merchant_card WHERE 
		merchant_id = :merch_card.merchant_id and
		card_type = :merch_card.card_type;

	if (SQLCODE < 0) {
		errcall(ERROR, "取商戶受理卡類表信息失敗[%ld]", SQLCODE);
		return -1;
	}

	if (SQLCODE == SQLNOTFOUND)
		return -2;

	del_st_space("merchant_card", &merch_card);
	memcpy(merchant_card, &merch_card, sizeof(S_merchant_card));

	return 0;
}

/***************************************************************
功能:
	根據商戶號到商戶受理卡類資料表中查找該商戶的受理卡類信息

ENTRY:
	S_merchant	包含該商戶的商戶號
	char *status	保存該商戶所受理的卡的使能信息
RETURN:
	0	SUCC
	-1	FAIL
****************************************************************/

int select_merchant_card_enable( S_merchant_card *merchant_c, char *status )
{
EXEC SQL BEGIN DECLARE SECTION;
S_merchant_card	merch_card;
char		m_id[20];
char		card_type[3];
char		bank_type[5];
char		sqlstr[256];
EXEC SQL END DECLARE SECTION;

	memset(m_id, '\0', sizeof(m_id));
	memset(card_type, '\0', sizeof(card_type));
	memset(bank_type, '\0', sizeof(bank_type));
	memset(sqlstr, '\0', sizeof(sqlstr));

	strcpy(m_id, merchant_c->merchant_id);
	strcpy( card_type, VISA_CARD);
	strcpy( bank_type, VISA_CARD);

	EXEC SQL SELECT * into :merch_card FROM merchant_card
		WHERE merchant_id = :m_id 
		AND card_type = :card_type
		AND bank_type = :bank_type;

	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[0] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[0] = '1';
		else
			status[0] = '0';
	}
	
	strcpy( card_type, MC_CARD);
	strcpy( bank_type, MC_CARD);

	EXEC SQL SELECT * into :merch_card FROM merchant_card
		WHERE merchant_id = :m_id 
		AND card_type = :card_type
		AND bank_type = :bank_type;

	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[1] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[1] = '1';
		else
			status[1] = '0';
	}
	
	strcpy( card_type, AE_CARD);
	strcpy( bank_type, AE_CARD);

	EXEC SQL SELECT * into :merch_card FROM merchant_card
		WHERE merchant_id = :m_id 
		AND card_type = :card_type
		AND bank_type = :bank_type;
	
	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[2] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[2] = '1';
		else
			status[2] = '0';
	}
	
	strcpy( card_type, DINER_CARD);
	strcpy( bank_type, DINER_CARD);

	EXEC SQL SELECT * into :merch_card FROM merchant_card
		WHERE merchant_id = :m_id 
		AND card_type = :card_type
		AND bank_type = :bank_type;
	
	if (SQLCODE < 0) { 
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[3] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[3] = '1';
		else
			status[3] = '0';
	}
	
	strcpy( card_type, JCB_CARD);
	strcpy( bank_type, JCB_CARD);

	EXEC SQL SELECT * into :merch_card FROM merchant_card
		WHERE merchant_id = :m_id 
		AND card_type = :card_type
		AND bank_type = :bank_type;
	
	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[4] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[4] = '1';
		else
			status[4] = '0';
	}

	strcpy( card_type, CREDIT_CARD);

	sprintf(sqlstr, "select * from merchant_card	\
		where	merchant_id	= \'%s\'	\
		and	card_type	= \'%s\'",
		m_id, 
		card_type);
	
	EXEC SQL PREPARE sel_merchant_card FROM :sqlstr;
	EXEC SQL DECLARE sel_merch_card CURSOR FOR sel_merchant_card;
	EXEC SQL OPEN sel_merch_card;

	if (SQLCODE < 0) {
		errcall(ERROR, "OPEN Select_merch_card err[%ld] [%s]", SQLCODE, sqlstr);
		return -1;
	}
	EXEC SQL FETCH sel_merch_card into :merch_card;
	
	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[5] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[5] = '1';
		else
			status[5] = '0';
	}

	EXEC SQL CLOSE sel_merch_card;
	if (SQLCODE < 0) {
		return -1;
	}
	
	strcpy( card_type, DEBIT_CARD);

	sprintf(sqlstr, "select * from merchant_card	\
		where	merchant_id	= \'%s\'	\
		and	card_type	= \'%s\'",
		m_id, 
		card_type);
	
	EXEC SQL PREPARE sel_m_card FROM :sqlstr;
	EXEC SQL DECLARE sel_mer_card CURSOR FOR sel_m_card;
	EXEC SQL OPEN sel_mer_card;

	if (SQLCODE < 0) {
		errcall(ERROR, "OPEN Select_merch_card err[%ld][%s]", SQLCODE, sqlstr);
		return -1;
	}
	EXEC SQL FETCH sel_mer_card into :merch_card;
	
	if (SQLCODE < 0) {
		return -1;
	}
	else if (SQLCODE == SQLNOTFOUND)
		status[6] = '0';
	else {
		if (merch_card.card_stat[0] == 'Y')
			status[6] = '1';
		else
			status[6] = '0';
	}
	
	EXEC SQL CLOSE sel_mer_card;
	if (SQLCODE < 0) {
		return -1;
	}
	
	return 0;
}

/***************************************************************
功能:
	將交易記錄插入存儲轉發表
ENTRY:
RETURN:
	0	SUCC
	-1	FAIL
****************************************************************/
int insert_saf ( S_saf_ls *s )
{
EXEC SQL BEGIN DECLARE SECTION;
S_saf_ls	l_saf_ls;
EXEC SQL END DECLARE SECTION;

	memcpy(&l_saf_ls, s, sizeof(S_saf_ls));
	
	EXEC SQL INSERT INTO saf_ls VALUES(:l_saf_ls);
	
	if (SQLCODE) {
		errcall(ERROR,"插入SAF流水表錯(%d)",SQLCODE);
		return -1;
	}

	return 0;
}

/***************************************************************
功能:
	根據終端號和商戶號取edc終端信息
ENTRY:
RETURN:
	0	SUCC
	-1	FAIL
	-2	NOTFOUND
****************************************************************/
int select_terminal ( S_edc_terminal *t )
{
EXEC SQL BEGIN DECLARE SECTION;
S_edc_terminal	l_edc_term;
EXEC SQL END DECLARE SECTION;

	memcpy(&l_edc_term, t, sizeof(S_edc_terminal));
	
	EXEC SQL SELECT * INTO :l_edc_term FROM edc_terminal
		WHERE terminal_id = :l_edc_term.terminal_id
		AND   merchant_id = :l_edc_term.merchant_id;
	
	if (SQLCODE == SQLNOTFOUND)
		return -2;
		
	if (SQLCODE < 0) {
		errcall(ERROR, "取EDC終端信息失敗[%ld]", SQLCODE);
		return -1;
	}
	
	del_st_space("edc_terminal", &l_edc_term);
	memcpy(t, &l_edc_term, sizeof(S_edc_terminal));
	
	return 0;
}

/***************************************************************
功能:
	根據終端號取edc終端信息
ENTRY:
RETURN:
	0	SUCC
	-1	FAIL
	-2	NOTFOUND
****************************************************************/
int select_terminal_base ( S_edc_terminal *t )
{
EXEC SQL BEGIN DECLARE SECTION;
S_edc_terminal	l_edc_term;
EXEC SQL END DECLARE SECTION;

	memcpy(&l_edc_term, t, sizeof(S_edc_terminal));
	
	EXEC SQL SELECT * INTO :l_edc_term FROM edc_terminal
		WHERE terminal_id = :l_edc_term.terminal_id;
	
	if (SQLCODE == SQLNOTFOUND)
		return -2;
		
	if (SQLCODE < 0) {
		errcall(ERROR, "取EDC終端信息失敗[%ld]", SQLCODE);
		return -1;
	}
	
	del_st_space("edc_terminal", &l_edc_term);
	memcpy(t, &l_edc_term, sizeof(S_edc_terminal));
	
	return 0;
}

/***************************************************************
功能:
	更新聯行簽到狀態標志
ENTRY:
RETURN:
	0	成功
	-1	失敗
****************************************************************/
int set_login_stat ( bankid, hostid, log_stat )
$parameter char *bankid;
$parameter char *hostid;
char log_stat;
{
EXEC SQL BEGIN DECLARE SECTION;
char 	l_stat;
EXEC SQL END DECLARE SECTION;
	
	l_stat = log_stat;
	
	begin_tran();
	EXEC SQL UPDATE bank_base set login_stat = :l_stat
		WHERE bank_id = :bankid 
		AND   host_id = :hostid;
	
	if (SQLCODE) {
		errcall(ERROR, "更新聯行[%s(%s)]簽到狀態標志失敗[%ld]!",
			bankid,
			hostid,
			SQLCODE);
		rollback_tran();
		return -1;
	}

	commit_tran();
	return 0;
}

$ifdef zgx020510_added;
$else;
/***************************************************************
功能:
	更新聯行網控器聯接標志
ENTRY:
RETURN:
	0	成功
	-1	失敗
****************************************************************/
int set_connect_stat( nacip, conn_stat )
char *nacip;
char conn_stat;
{
EXEC SQL BEGIN DECLARE SECTION;
char 	l_stat;
char 	bankid[12];
char 	hostid[3];
char	nac_ip[128];
EXEC SQL END DECLARE SECTION;
#ifdef wyz020923_modi
#else
int	retry_cnt=0;
#endif
	
	l_stat = conn_stat;
	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品久久一牛影视| 国产91精品免费| 国产精品久久久久久亚洲伦| 日韩欧美一区在线观看| 欧美日韩一级视频| 欧洲国产伦久久久久久久| 91麻豆免费观看| av一区二区三区| 91一区二区在线观看| 丁香婷婷综合色啪| bt7086福利一区国产| 成人性生交大片免费看中文 | 欧美精品一区二区三区在线| 欧美日韩国产小视频在线观看| 一本一道综合狠狠老| 欧美性猛交xxxx黑人交| 欧美日韩一区二区在线视频| 欧美经典三级视频一区二区三区| 波多野结衣欧美| 国产美女av一区二区三区| 亚洲成人激情自拍| 蜜臀久久99精品久久久久久9 | 性欧美疯狂xxxxbbbb| 亚洲成av人片| 久久爱www久久做| 粉嫩在线一区二区三区视频| 99久久精品99国产精品| 欧美日韩一级片网站| 日韩精品一区二区三区在线播放| 久久在线免费观看| 亚洲品质自拍视频| 日本视频一区二区三区| 国产在线精品一区二区不卡了| eeuss影院一区二区三区 | 免费成人在线观看| 精品一区二区免费| 91污片在线观看| 日韩一级黄色大片| 亚洲精品视频在线观看网站| 奇米一区二区三区| 91在线小视频| 亚洲精品在线三区| 亚洲最色的网站| 国产精品综合网| 欧美在线高清视频| 国产精品国产精品国产专区不片| 亚洲香肠在线观看| 波波电影院一区二区三区| 在线不卡免费欧美| 亚洲欧洲性图库| 国产在线一区观看| 欧美日韩国产小视频在线观看| 国产视频一区二区三区在线观看| 亚洲女厕所小便bbb| 狠狠色丁香久久婷婷综| 欧美日韩久久不卡| 亚洲精品综合在线| 国产成人免费xxxxxxxx| 日韩视频免费直播| 亚洲一区二区五区| 99久久亚洲一区二区三区青草| 26uuu色噜噜精品一区二区| 三级影片在线观看欧美日韩一区二区 | 亚洲欧洲性图库| 国产一区二区三区四区五区入口| 欧美日韩精品欧美日韩精品 | 99久久精品国产网站| 久久综合色之久久综合| 免费看黄色91| 欧美亚州韩日在线看免费版国语版| 国产亚洲综合性久久久影院| 在线成人av网站| 亚洲电影第三页| 色av一区二区| 亚洲一区二区在线免费看| 97精品视频在线观看自产线路二 | 福利一区二区在线| 欧美一区二区三区免费| 日韩精品一卡二卡三卡四卡无卡| 亚洲成av人片在www色猫咪| 不卡电影免费在线播放一区| 久久久精品国产免大香伊 | 亚洲欧美成aⅴ人在线观看| 成年人午夜久久久| 中文字幕在线观看不卡视频| 成人av网址在线| 成人欧美一区二区三区1314| 99re视频这里只有精品| 国产清纯在线一区二区www| 国产一区三区三区| 中文久久乱码一区二区| 99这里只有久久精品视频| **网站欧美大片在线观看| 91久久线看在观草草青青| 图片区日韩欧美亚洲| 欧美成人官网二区| 国产成a人亚洲精| 亚洲欧美日韩在线播放| caoporm超碰国产精品| 亚洲一区二区影院| 精品88久久久久88久久久 | 亚洲色图制服丝袜| 欧美系列一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲国产精品麻豆| 91麻豆精品在线观看| 亚洲综合在线免费观看| 精品91自产拍在线观看一区| 成人一区二区三区视频在线观看| 亚洲欧美乱综合| 欧美日韩国产免费一区二区| 国产又粗又猛又爽又黄91精品| 亚洲欧美日韩成人高清在线一区| 欧美一区二区三区电影| 成人激情免费视频| 一区二区日韩电影| 欧美中文字幕不卡| 亚洲成人午夜电影| 不卡影院免费观看| 中文字幕视频一区| 日本欧美在线观看| 欧美疯狂性受xxxxx喷水图片| 激情小说亚洲一区| 成人av在线播放网址| 亚洲va韩国va欧美va精品| 欧美日韩在线播放一区| 成人免费视频视频| 亚洲裸体在线观看| 国产欧美一区二区三区在线看蜜臀 | 日本午夜一本久久久综合| 亚洲精品在线观看网站| 欧美日韩亚洲综合一区| 男女视频一区二区| 中文字幕免费在线观看视频一区| 国模娜娜一区二区三区| 欧美图区在线视频| 久久久精品tv| 亚洲欧美aⅴ...| 国产精品二三区| 欧美精品aⅴ在线视频| 精品亚洲porn| 国产精品视频一区二区三区不卡 | 日韩免费高清av| 在线亚洲欧美专区二区| 美女在线一区二区| 日韩av午夜在线观看| 国产精品午夜免费| 欧美韩日一区二区三区四区| 欧美日韩午夜在线视频| 欧美亚洲尤物久久| 成人小视频在线| 国产91富婆露脸刺激对白| **性色生活片久久毛片| 91精品国产色综合久久不卡蜜臀| 国产成人av影院| 国产毛片一区二区| 秋霞影院一区二区| 日本一区二区电影| 欧美一区二区三区白人| 欧美一区二区福利视频| 日本乱码高清不卡字幕| 91丨porny丨户外露出| 韩国精品主播一区二区在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲香肠在线观看| 欧美疯狂性受xxxxx喷水图片| 91亚洲精华国产精华精华液| 国产一区二区三区免费看 | 成人免费毛片嘿嘿连载视频| 图片区日韩欧美亚洲| 麻豆精品视频在线观看视频| 亚洲国产中文字幕| 蜜桃av一区二区三区电影| 亚洲一级二级三级在线免费观看| 亚洲mv大片欧洲mv大片精品| 自拍偷拍亚洲综合| 亚洲成人在线网站| 一区二区三区av电影 | 日韩限制级电影在线观看| 一本到不卡免费一区二区| 欧美亚洲免费在线一区| 99久久精品免费精品国产| 在线观看av一区二区| 99久精品国产| 91精品国产综合久久精品| 6080日韩午夜伦伦午夜伦| 久久99精品国产.久久久久| 日韩精品欧美精品| 国产成人日日夜夜| 国产一区 二区| 色哟哟一区二区在线观看| 91麻豆国产香蕉久久精品| 欧美一区二区成人6969| 日韩欧美aaaaaa| 有码一区二区三区| 香港成人在线视频| 成人综合日日夜夜| 91浏览器在线视频| 久久久高清一区二区三区| 中文字幕的久久|