Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window7 32bit , Window10 64bit
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
c#


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
쿼리를 실행하는 도중 에러가 발생하여 응용프로그램이 팅겼습니다.

 

이 현상은 지속적으로 일어나는것이 아니라 계속 켜놓고있다보면 한번씩 나타나는 증상입니다.

 

20초에 한번씩 쿼리를 지속적으로 돌립니다.

 

로그는 윈도우 이벤트 로그입니다.

 

응용 프로그램: OrderNotice.exe
Framework 버전: v4.0.30319
설명: 처리되지 않은 예외로 인해 프로세스가 종료되었습니다.
예외 정보:System.AccessViolationException
스택:
   위치: System.Data.OleDb.SessionWrapper.CreateCommand(System.Object ByRef)
   위치: System.Data.OleDb.OleDbConnectionInternal.ICommandText()
   위치: System.Data.OleDb.OleDbConnection.ICommandText()
   위치: System.Data.OleDb.OleDbCommand.PropertiesOnCommand(Boolean)
   위치: System.Data.OleDb.OleDbCommand.InitializeCommand(System.Data.CommandBehavior, Boolean)
   위치: System.Data.OleDb.OleDbCommand.ExecuteCommand(System.Data.CommandBehavior, System.Object ByRef)
   위치: System.Data.OleDb.OleDbCommand.ExecuteReaderInternal(System.Data.CommandBehavior, System.String)
   위치: System.Data.OleDb.OleDbCommand.ExecuteReader(System.Data.CommandBehavior)
   위치: System.Data.OleDb.OleDbCommand.System.Data.IDbCommand.ExecuteReader(System.Data.CommandBehavior)
   위치: System.Data.Common.DbDataAdapter.FillInternal(System.Data.DataSet, System.Data.DataTable[], Int32, Int32, System.String, System.Data.IDbCommand, System.Data.CommandBehavior)
   위치: System.Data.Common.DbDataAdapter.Fill(System.Data.DataSet, Int32, Int32, System.String, System.Data.IDbCommand, System.Data.CommandBehavior)
   위치: System.Data.Common.DbDataAdapter.Fill(System.Data.DataSet)
   위치: OrderTracker.Shared.DBPoll.GetNewOrdersYN(System.String)
   위치: OrderTracker.Pages.FrmHome.timer1_Tick(System.Object, System.EventArgs)
   위치: System.Windows.Forms.Timer.OnTick(System.EventArgs)
   위치: System.Windows.Forms.Timer+TimerNativeWindow.WndProc(System.Windows.Forms.Message ByRef)
   위치: System.Windows.Forms.NativeWindow.Callback(IntPtr, Int32, IntPtr, IntPtr)
   위치: System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG ByRef)
   위치: System.Windows.Forms.Application+ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr, Int32, Int32)
   위치: System.Windows.Forms.Application+ThreadContext.RunMessageLoopInner(Int32, System.Windows.Forms.ApplicationContext)
   위치: System.Windows.Forms.Application+ThreadContext.RunMessageLoop(Int32, System.Windows.Forms.ApplicationContext)
   위치: System.Windows.Forms.Application.Run(System.Windows.Forms.Form)
   위치: OrderNotice.Program.Main(System.String[])

 

----------------------------------------------------함수내용-----------------------------------------------------------

 

public string[] GetNewOrdersYN(string esntl_cust_id)
        {
            string[] result = new string[] { "","", "" };

            try
            {
                string SQL = "SELECT MAX(new_order) AS new_order, DECODE(MAX(ISNULL(ORDER_DATE_LAST_TIM)), 0, 'Y', 'N') AS new_job                     \n";
                       SQL += ", TO_CHAR(MAX(ORDER_DATE_LAST_TIM), 'YYYY-MM-DD HH24:MI:SS') AS ORDER_DATE_LAST_TIM                                    \n";              
                       SQL += "FROM (SELECT DECODE(COUNT(*), 0, 'N', 'Y') AS new_order, '' AS ORDER_DATE_LAST_TIM                                               \n";
                       SQL += "FROM artsend                                                                                                                                                 \n";
                       SQL += "WHERE esntl_cust_id = '"+ esntl_cust_id + "'                                                                                                          \n";
                       SQL += "and ORDER_DT BETWEEN(NOW()-(1000 * 60 * 60 * 24)) AND NOW()                                                                          \n";
                       SQL += "and order_sta = 'O'                                                                                                                                          \n";
                       SQL += "UNION all                                                                                                                                                      \n";
                       SQL += "SELECT '', to_char(MAX(chg_date),  'yyyy-mm-dd hh24:mi:ss') AS ORDER_DATE_LAST_TIM                                                \n";
                       SQL += "FROM artsend                                                                                                                                                \n";
                       SQL += "WHERE esntl_cust_id = '" + esntl_cust_id + "'                                                                                                        \n";
                       SQL += "and to_char(chg_date, 'yyyy-mm-dd hh24:mi:ss') > '" + Global.last_tm + "')                                                                  \n";

 

                OleDbDataAdapter ad = new OleDbDataAdapter(SQL, DBConn.conn);

                Console.WriteLine(SQL);

                DataSet ds = new DataSet();
                ad.Fill(ds);
                DataTable dt = ds.Tables[0];

                if (ds.Tables.Count > 0)
                {
                    foreach(DataRow r in dt.Rows)
                    {
                        result[0] = r["new_order"].ToString();
                        result[1] = r["new_job"].ToString();
                        result[2] = r["ORDER_DATE_LAST_TIM"].ToString();
                        
                        Console.WriteLine("new_order : " + result[0]);
                        Console.WriteLine("new_job : " + result[1]);
                        Console.WriteLine("last_tm : " + result[2]);
                    }
                    return result;
                }
                else
                {
                    return null;
                }
            }
            catch (Exception ex)
            {
                return null;
            }
        }

 


 

 

  • ?
    airnet 2021.06.08 09:33
    안녕하세요
    큐브리드를 이용해 주셔서 감사합니다.

    보내주신 로그에는 cubrid oledb driver의 함수 호출 내역이 없어 정확한 분석이 어려워
    주기적으로(20초 간격) query를 수행 하는 테스트 코드를 작성 하여, 15시간 정도 테스트를 진행 했습니다만 제현이 되지 않았습니다.
    혹시 db의 실 데이터를 주시기 어렵다면 cubrid 에서 제공되는 demodb를 이용 하여 제현되는 코드를 전달해 주시면 검토해 보겠습니다.
    그리고, 사용하신 버전을 기제해 주시면 디버깅에 많은 도움이 됩니다.

    감사합니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3974 mysql로 DB연동 문의 3 연동테스트용 2024.03.20 74
3973 특정DB만 접근 시간이 현저하게 오래 걸리는 문제 1 file 그로구 2024.03.20 64
3972 jdbc 연동시의 charset 강제 변경 방법 1 file gwak 2024.03.14 57
3971 도커로 HA환경 구성 테스트중 hb start.. 1 wodud0170 2024.03.12 63
3970 이중화 관련 문의드립니다. 1 adqwdqwd123412 2024.03.12 67
3969 큐브리드 마스터 복제 관련 문의 드립니다. 2 이지혜 2024.03.11 61
3968 큐브리드 다운로드 에러 1 file 나래아빠 2024.03.08 85
3967 CUBRID Migration Toolkit "orai18n.jar" 추가 방법 1 가을이아빠 2024.03.07 59
3966 CUBRID 에러 로그 관련 확인 요청 2 jnj570244 2024.03.07 95
3965 DB링크로 조회시 문자타입이 조회되지 않고 있습니다. 2 file 원샷 2024.03.06 93
3964 다른 사용자 계정에서 csql로 localhost 접근 문제 4 가을이아빠 2024.03.05 79
3963 [성능이슈] 큐브리드 함수 사용으로 인한 성능이슈 3 레고 2024.03.04 113
3962 CUBRID 11.2 rpm 설치시 cubrid 계정 패스워드 2 가을이아빠 2024.03.04 54
3961 Cubrid JDBC 버전에 따라 출력되는 결과가 다릅니다. 1 엘L 2024.02.28 89
3960 select 질의문 문의 2 태리 2024.02.26 119
3959 cubrid statdump 기술 문의드립니다. 5 secret 이건우 2024.02.19 11
3958 날짜 형식 변환에 대해서 궁금해서 올립니다. 1 김용용 2024.02.14 56
3957 컬럼의 Enum DataType 가져오는것 문의 3 엘L 2024.01.30 75
3956 Redhat 8버전 tls 1.0 에러 9 11시38분 2024.01.30 120
3955 테이블이 어떤 스키마(데이터베이스)에 속해있는지 알 수 있는 방법이 있나요? 3 엘L 2024.01.29 117
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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