* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Windows 2012 64Bit | |
9.3.2.0016 64Bit | |
[도움말]-[버전정보] 확인 | |
CUBRID ADO.NET Data Provider 9.3.0.0003 |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
아래 질문을 올렸으나 답변이 없어서 다시 올립니다.
try
{
//create table t(f1 varchar(100), f2 varchar(100));
//insert into t values('aa', 'bb');
string query = "select * from t";
CUBRIDDataAdapter ad = new CUBRIDDataAdapter(query, con);
DataTable dt = new DataTable();
ad.Fill(dt); // 예외 발생
ad.Dispose();
}
catch (CUBRID.Data.CUBRIDClient.CUBRIDException ex)
{
System.Console.WriteLine(ex); //"DataReader.GetFieldType(0)에서 null을 반환했습니다."
}
위와 같은 코드를 실행하면 "ad.Fill(dt);" 부분에서 예외가 발생합니다.
대상 프레임워크를 .Net Framework 3.0 이나 3.5에서는 정상적으로 동작하지만
.Net Framework 4로 설정하여 실행하면 예외가 발생합니다.
규브리드는 64Bit로 설치되어 있으며 플랫폼을 x64로 하여 cascci64.dll 를 사용할 경우 예외가 발생합니다.
플랫폼을 x86으로 하여 cascci32.dll 를 사용할 경우 정상 동작합니다.
안녕하세요 큐브리드 진우진입니다.
"select * from t" 질의 결과에 대한 데이터 저장을 원하실 때는
CUBRIDDataAdapter 클래스 대신 CUBRIDDataReader 클래스를 이용하셔야 합니다.
사용 예제는 다음과 같습니다.
using (CUBRIDCommand cmd = new CUBRIDCommand("select * from t", conn))
{
CUBRIDDataReader reader = (CUBRIDDataReader)cmd.ExecuteReader();
reader.Read();
Debug.Assert(reader.GetDateTime(0) == new DateTime(2008, 10, 31, 10, 20, 30, 040));
Debug.Assert(reader.GetDate(0) == "2008-10-31");
Debug.Assert(reader.GetDate(0, "yy/MM/dd") == "08/10/31");
Debug.Assert(reader.GetTime(0) == "10:20:30");
Debug.Assert(reader.GetTime(0, "HH") == "10");
Debug.Assert(reader.GetTimestamp(0) == "2008-10-31 10:20:30.040");
Debug.Assert(reader.GetTimestamp(0, "yyyy HH") == "2008 10");
}
자세한 기능 및 사용법은 아래 링크 참조하시면 됩니다.
http://ftp.cubrid.org/CUBRID_Docs/Drivers/ADO.NET/9.3.0/class_c_u_b_r_i_d_1_1_data_1_1_c_u_b_r_i_d_client_1_1_c_u_b_r_i_d_data_reader.html