Background Image

FORUM

조회 수 8233 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

도저히 답을 찾지 못해 도움을 청합니다.
Van사에서 가상계좌에 입금된 내용을 받아 DB에 저장 시키는 소스인데 현재  7.3에서 원활히 동작되고 있는 소스입니다.
그런데, R1.4로 옮긴 후 데이터가 저장이 되질 않습니다.ㅜㅜ
이것 때문에 4일째 헤매고 있는데 원인을 찾질 못하고 있습니다.
아래(빨간색) 함수에 오류나 나는 것 같은데 정확히 문제를 해결하지 못하고 있습니다.

제발 좀 도와 주세요ㅜㅜ
아래처럼 실행시 메세지가 나타납니다.
----------------실행 메세지
Connect to DB .... OK!
no_account[40600000097022]
nm_bank[기업은행  ]
nm_receipt[가나다              ]
SELECT CD_VENDOR, NM_NICK, CD_CONTACT, NO_VT_ACC FROM VENDOR_SETUP WHERE NO_VT_ACC='40600000097022'
o_cd_vendor=[(null)]
o_nm_vendor=[(null)]
o_cd_staff=[(null)]
데아타 저장/중복체크
SELECT COUNT(*) FROM RECEIPT_MASTER WHERE NO_MESSAGE='0002000050'
가입금 채번시작
저장실패/데이터중복


----------------------- 소스
#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdarg.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>
#include "cas_cci.h"

char *buffer;
char strbuf[50];
char *cd_vendor;
char *nm_vendor;
char *st_mobile;
char *nm_staff;
char *cd_staff;
char *ct_mobile;
char *nm_contact;
char *am_remain;
char *no_serial;

char *receiptno;
char *dy_receipt;
char *dy_current;

int con = 0,res=0;
int req = 0, ind, i, col_count;
int recnt=0;
int ctcnt = 0;
T_CCI_ERROR error;
T_CCI_SQLX_CMD cmd_type;
T_CCI_COL_INFO *res_col_info;

int db_proc(char *);
int sms_send(char *, char *, char *, char *, char *, char *, char *);
int insert_receipt2(char *, int);
int insert_receipt3(char *);
int select_receiptno();
int select_ctcnt(char *);
void select_staff(char *);
long select_initMisu(char *);
long select_trMisu(char *, char *);
char *strmcpy(char *,int,int);
void select_vendor(char *);
void select_contact(char *);
int select_resend(char *);
void delchar(char*, const char*);
char *commify(double, char *, int);

int db_main(char buff[1000])
//int main()
{
     char *cas_ip = "localhost";
     int cas_port = 33000;
     char *dbname = "aaaa";
 
 con = cci_connect(cas_ip, cas_port, dbname, "dba", "aaaa");
 if( con <  0 ) {
            //err_rtn();
            return 1;
        }
 else
     printf("Connect to DB .... OK! n");      
        switch(buff[71]){
           case '1' : /* 입금취소 */
                 if (db_proc(buff)==0)
                 {
                     printf("저장성공n");
                   res = cci_disconnect(con, &error);
                     return 0;
                 }
                 else
                 {
                     printf("저장실패/데이타중복n");
                    res = cci_disconnect(con, &error);
                     return 3;
                 }
           case '2' : /* 정산집계 */
                  res = cci_disconnect(con, &error);
                  return 4;
           case '4' : /* 수취조회 */
                 res = cci_disconnect(con, &error);
                 return 5;
                default:
                res = cci_disconnect(con, &error);
                 break;
        }

 res = cci_disconnect(con, &error);
 printf(" DisConnect to DB [ eBlind ] .... OK! n");
 if( res < 0 ) {
            //err_rtn();
            return 2;
        }
 else
     printf(" Disconnect DB [ eBlind ] .... OK! n");
 return 0;
}

int db_proc(char *buff)
{
        /*
        char *no_msg=strmcpy(buff,34,10);
        if (select_resend(no_msg)>0)
              return 9;
        */
        switch(buff[68])
        {
           case '2' : /* 입금 */
                  return insert_receipt2(buff,2);
           case '4' : /* 취소 */
                  return insert_receipt2(buff,3);
        }
        return 0;
}

void select_staff(char *cd_Staff)
{
        char query[500];

 sprintf(query,"SELECT NM_STAFF, nvl(NO_MOBILE,'') as MOBILE  FROM STAFF_MASTER WHERE CD_STAFF='%s'",cd_Staff);
        if ((req=cci_prepare(con, query,0,&error))<0)
             return;

        printf(query);
        printf("n");

        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return;
        if ((res=cci_fetch_size(req, 100))<0)
             return;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return;
        if ((res=cci_fetch(req, &error))<0)
             return;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_STR, &nm_staff, &ind))<0)
             return;
        if ((res=cci_get_data(req, 2, CCI_A_TYPE_STR, &st_mobile, &ind))<0)
             return;
        if ((res=cci_close_req_handle(req))<0)
             return;
        //return st_mobile;
}

void select_vendor(char *no_account)
{
        char query[500];

 sprintf(query,"SELECT CD_VENDOR, NM_NICK, CD_CONTACT, NO_VT_ACC FROM VENDOR_SETUP WHERE NO_VT_ACC='%s'",no_account);

        printf(query);
        printf("n");

        if ((req=cci_prepare(con, query,0,&error))<0)
             return;
        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return;
        if ((res=cci_fetch_size(req, 100))<0)
             return;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return;
        if ((res=cci_fetch(req, &error))<0)
             return;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_STR, &cd_vendor, &ind))<0)
             return;
        if ((res=cci_get_data(req, 2, CCI_A_TYPE_STR, &nm_vendor, &ind))<0)
             return;
        if ((res=cci_get_data(req, 3, CCI_A_TYPE_STR, &cd_staff, &ind))<0)
             return;
        if ((res=cci_close_req_handle(req))<0)
             return;
 
        printf("cdVendor=%sn",cd_vendor);
        printf("nmVendor=%sn",nm_vendor);
        printf("cdstaff=%sn",cd_staff);

}

int select_ctcnt(char *cd_Vendor)
{
        char query[500];

 sprintf(query,"SELECT COUNT(*) FROM VENDOR_CONTACT WHERE SUBSTR(CD_CONTACT,1,6)='%s'",cd_Vendor);
        if ((req=cci_prepare(con, query,0,&error))<0)
             return 1;

        printf(query);
        printf("n");

        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return 1;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return 1;
        if ((res=cci_fetch_size(req, 100))<0)
             return 1;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return 1;
        if ((res=cci_fetch(req, &error))<0)
             return 1;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_INT, &ctcnt, &ind))<0)
             return 1;
        if ((res=cci_close_req_handle(req))<0)
             return 1;
        return 0;
}

void select_contact(char *cd_Vendor)
{
        char query[500];

 sprintf(query,"SELECT NM_CONTACT, nvl(NO_MOBILE,'') as MOBILE FROM VENDOR_CONTACT WHERE SUBSTR(CD_CONTACT,1,6)='%s'",cd_Vendor);
        if ((req=cci_prepare(con, query,0,&error))<0)
             return;
        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return;
        if ((res=cci_fetch_size(req, 100))<0)
             return;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return;
        if ((res=cci_fetch(req, &error))<0)
             return;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_STR, &nm_contact, &ind))<0)
             return;
        if ((res=cci_get_data(req, 2, CCI_A_TYPE_STR, &ct_mobile, &ind))<0)
             return;
        if ((res=cci_close_req_handle(req))<0)
             return;
}

long select_initMisu(char *cd_vendor)
{      
        char query[500];
        long initamt;

        initamt=0;

        sprintf(query,"SELECT nvl(AM_INITIAL,0) FROM VENDOR_SETUP WHERE CD_VENDOR='%s'",cd_vendor);
        if ((req=cci_prepare(con, query,0,&error))<0)
             return 0;
        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return 0;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return 0;
        if ((res=cci_fetch_size(req, 100))<0)
             return 0;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return 0;
        if ((res=cci_fetch(req, &error))<0)
             return 0;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_INT, &initamt, &ind))<0)
             return 0;
        if ((res=cci_close_req_handle(req))<0)
             return 0;

        return initamt;
}

long select_trMisu(char *oDate, char *cd_vendor)
{
        char query[5000];
        long trmisu;

        trmisu=0;

     sprintf(query, "SELECT (SUM(A.misuAmt)-SUM(A.trInAmt)) AS misu FROM (SELECT nvl(sum(T.am_trade),0) as misuAmt, 0 AS trInAmt FROM order_master O, trade_master T WHERE O.no_order=substr(T.no_order,1,10) AND O.cd_vendor='%s' and T.dy_trade <= '%s' UNION SELECT nvl(sum(L.am_total),0) as misuAmt, 0 AS trInAmt FROM order_master O, order_list L WHERE O.no_order=L.no_order AND O.cd_vendor='%s' and O.dy_order<='%s' AND (O.fg_order='1' or O.fg_order='3') and nvl(L.fg_ordlist,'')<'4' UNION SELECT 0 AS misuAmt, (nvl(sum(R.am_receipt),0)+nvl(sum(R.am_disc),0)) as trInAmt FROM receipt_master R WHERE R.cd_vendor='%s' and R.dy_receipt <= '%s') A",cd_vendor, oDate, cd_vendor, oDate, cd_vendor, oDate);
       
        if ((req=cci_prepare(con, query,0,&error))<0)
             return 0;
        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return 0;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return 0;
        if ((res=cci_fetch_size(req, 100))<0)
             return 0;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return 0;
        if ((res=cci_fetch(req, &error))<0)
             return 0;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_INT, &trmisu, &ind))<0)
             return 0;
        if ((res=cci_close_req_handle(req))<0)
             return 0;

        return trmisu;
}

int select_receiptno()
{
        if ((req=cci_prepare(con, "SELECT TO_CHAR(sysdate,'yyMMdd') || LPAD(TO_CHAR(NVL(MAX(TO_NUMBER(SUBSTR(NO_RECEIPT,7,4))), 0)+1),4,'0'),TO_CHAR(sysdate,'yyyy-MM-dd'),TO_CHAR(systimestamp,'yyyyMMddhh24mi') FROM RECEIPT_MASTER WHERE SUBSTR(NO_RECEIPT,1,6)=TO_CHAR(sysdate,'yyMMdd')",0,&error))<0)
             return 1;
        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return 1;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return 1;
        if ((res=cci_fetch_size(req, 100))<0)
             return 1;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return 1;
        if ((res=cci_fetch(req, &error))<0)
             return 1;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_STR, &receiptno, &ind))<0)
             return 1;
        if ((res=cci_get_data(req, 2, CCI_A_TYPE_STR, &dy_receipt, &ind))<0)
             return 1;
        if ((res=cci_get_data(req, 3, CCI_A_TYPE_STR, &dy_current, &ind))<0)
             return 1;
        if ((res=cci_close_req_handle(req))<0)
             return 1;
     
        printf(receiptno);
        printf("n");
        printf(dy_receipt);
        printf("n");
        printf(dy_current);
        printf("n");
     

        return 0;
}

int select_resend(char *no_msg)
{
        char query[500];

 sprintf(query,"SELECT COUNT(*) FROM RECEIPT_MASTER WHERE NO_MESSAGE='%s'",no_msg);
        if ((req=cci_prepare(con, query,0,&error))<0)
             return -1;

        printf(query);
        printf("n");

        res_col_info = cci_get_result_info(req, &cmd_type, &col_count);
        if (!res_col_info)
             return -1;
        if ((res=cci_execute(req, 0, 0, &error))<0)
             return -1;
        if ((res=cci_fetch_size(req, 100))<0)
             return -1;
        res = cci_cursor(req, 0, CCI_CURSOR_CURRENT, &error);
        if (res<0)
             return -1;
        if ((res=cci_fetch(req, &error))<0)
             return -1;
        if ((res=cci_get_data(req, 1, CCI_A_TYPE_INT, &recnt, &ind))<0)
             return -1;
        if ((res=cci_close_req_handle(req))<0)
             return -1;
        return recnt;
}

int insert_receipt2(char *buff, int flag)
{
        char query[500];

        char vendor[50];
        char sms_msg[200];
        char sms_msg1[200];
        char dest[40];

        char o_receiptno[20];
        char o_dy_receipt[20];
        char o_dy_current[20];

        char o_am_receipt[20];
        char o_no_account[20];
        char o_no_message[20];

        char o_nm_bank[10];
        char o_nm_receipt[20];

        char o_cd_vendor[20];
        char o_nm_vendor[40];
        char o_cd_staff[20];

        char o_nm_staff[20];
        char o_st_mobile[20];
        char o_ct_mobile[20];

   memset(o_st_mobile,'

  • ?
    cubebridge 2009.12.07 20:08
    해당 문제에 대해서는 유선으로 답변을 드렸습니다.
    프로그램 로직에 관련하여 개발 담당자에 확인하시기 바랍니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 63
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4464
3459 DB복구 3 hoon 2017.11.08 1028
3458 DB복구 질문 드립니다. 3 hoon 2017.11.07 306
3457 DB복구 질문드립니다. 7 hoon 2017.11.09 933
3456 DB삭제 오류 관련 문의 3 file sklee 2019.05.02 362
3455 DB생성시 문자집합 변경 1 까망이 2012.07.31 7138
3454 DB서버 에러로그 1 file leeee 2023.12.27 120
3453 DB서버 이중화작업에 큐브리드를 적용하는 법이 알고 싶습니다. 1 거지같은 2014.06.25 9318
3452 DB수가 많을때 다중 브로커 문의드립니다 1 유니콘 2013.05.08 10136
3451 DB에 BLOB 저장 관련입니다. 2 안녕하세요 2011.10.18 24230
» DB에 자료가 저장이 안되는데 도움을 부탁드립니다. 1 푸른잔디 2009.12.07 8233
3449 DB연계 관련하여 문의 드립니다. 2 uzins 2020.11.23 159
3448 DB연계과정에서 에러코드 발생되어 문의 드립니다. 1 file kik 2017.11.20 347
3447 DB와 BROKER 분리 설정 방법 1 땡글이와밍크 2015.03.26 6171
3446 DB용량을 정확하게 줄이려면 1 해인파더 2013.05.31 8695
3445 DB의 콜레이션(문자진합)을 조회하는 쿼리(신텍스)가 있나요? 2 덴드로비움 2017.07.31 802
3444 DB접속 -677 오류 1 file gu04 2021.12.28 291
3443 DB접속이 안됩니다. 1889번 글로 재질문 드립니다. 2 CUBRID 2014.07.08 5659
3442 DB접속이 안됩니다. 질문 드려요. 1 CUBRID 2014.07.07 6503
3441 DB코맨트 쿼리와 한글 처리 문제 질문드립니다. 1 아라아 2018.07.02 328
3440 DECODE 함수 사용시 문제 발생건 1 지성 2018.06.07 1156
Board Pagination Prev 1 ... 23 24 25 26 27 28 29 30 31 32 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales