Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

닷넷에서 SAP Adaptive Server Enterprise 데이터베이스 사용

SAP의 ASE 데이터베이스가 있는데, 저도 처음 다운로드 받아서 테스트 환경을 구성해봤습니다. 근데, 실행 파일이름이 sqlsrvr.exe라서 자칫 마이크로소프트의 SQL 서버로 착각할 수 있습니다. ^^; 실행 파일 경로를 보면 답이 나오지만.

C:\SAP\ASE-16_0\bin\sqlsrvr.exe

어쨌든 테스트는 전통적인 ADO.NET 방식으로 동일하게 할 수 있습니다.

String host = "...";
String port = "5000";
String user = "...";
String pass = "...";

using (AseConnection conn = new AseConnection("PROVIDER=ASEOLEDB.1;Data Source='" +
    host + "';Port='" + port + "';UID='" + user + "';PWD='" + pass + "';Database='testdb';"))
{
    conn.Open();

    AseCommand cmd = new AseCommand("select * from testtable", conn);
    AseDataReader reader = cmd.ExecuteReader();
    StringBuilder sb = new StringBuilder();

    while (reader.Read())
    {
        sb.Append(reader.GetString(0));
    }

    Console.WriteLine("Result: " + sb.ToString());

    conn.Close();
}

이를 위해 서버 설치 시 함께 복사된 Sybase.AdoNet4.AseClient.dll, Sybase.AdoNet35.AseClient.dll 어셈블리를 닷넷 버전에 맞게 참조해서 쓰면 됩니다. 배포도 매우 쉬운데요. 참조한 그 Sybase.AdoNet???.AseClient.dll 어셈블리만 함께 배포하면 끝입니다. ^^

하지만, 아쉽게도 다음과 같은 오류가 발생하는군요. ^^

Exception thrown: 'Sybase.Data.AseClient.AseException' in Sybase.AdoNet4.AseClient.dll
System.Transactions Critical: 0 : <TraceRecord xmlns="http://schemas.microsoft.com/2004/10/E2ETraceEvent/TraceRecord" Severity="Critical"><TraceIdentifier>http://msdn.microsoft.com/TraceCodes/System/ActivityTracing/2004/07/Reliability/Exception/Unhandled</TraceIdentifier><Description>Unhandled exception</Description><AppDomain>ConsoleApplication1.vshost.exe</AppDomain><Exception><ExceptionType>Sybase.Data.AseClient.AseException, Sybase.AdoNet4.AseClient, Version=16.0.2.0, Culture=neutral, PublicKeyToken=95d94fac46c88e1e</ExceptionType>
<Message>Could not load code page for requested charset</Message><StackTrace>   at Sybase.Data.AseClient1.AseConnection.Open()
   at Sybase.Data.AseClient.AseConnection.Open()
   at ConsoleApplication1.Program.Main(String[] args) in E:\ConsoleApplication1\Program.cs:line 22
   at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
   at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
   at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
   at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
   at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
   at System.Threading.ThreadHelper.ThreadStart()</StackTrace>
<ExceptionString>Sybase.Data.AseClient.AseException: Could not load code page for requested charset
   at Sybase.Data.AseClient1.AseConnection.Open()
   at Sybase.Data.AseClient.AseConnection.Open()
   at ConsoleApplication1.Program.Main(String[] args) in E:\ConsoleApplication1\Program.cs:line 22
   at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
   at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
   at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
   at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
   at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
   at System.Threading.ThreadHelper.ThreadStart()</ExceptionString></Exception></TraceRecord>

"Could not load code page for requested charset"라는 오류 메시지인데요. 이상한 점은 DB 설치 시에 cp850으로 했었기 때문에 다음과 같이 연결 문자열을 구성해도 마찬가지 오류가 발생한다는 것입니다.

PROVIDER=ASEOLEDB.1;Data Source=...;Port=5000;UID=...;PWD=...;Database='testdb';CHARSET=cp850

검색해 보니 다음의 글이 나오는데요.

Connecting to ASE 15.7 from Windows Server 2012 
; https://scn.sap.com/thread/3669701

cp850이 아닌, iso_1로 지정해야 된다는 것입니다. 어쨌든 다음과 같이 연결 문자열을 구성하면 잘 됩니다.

PROVIDER=ASEOLEDB.1;Data Source=...;Port=5000;UID=...;PWD=...;Database='testdb';CHARSET=iso_1

첨부한 파일은 위의 예제를 구성한 솔루션입니다.




설치 중에 발생했던 문제 하나 공유합니다. ^^ 제 경우에 다음과 같이 "Installing character set 'cp850'"이라는 메시지만 반복되면서 설치가 더 이상 진행되지 않는 현상이 있었습니다.

sybase_ase_install_1.png

Process Explorer로 보니 이때 실행 중인 셋업 프로세스의 하위로 charset.exe가 있었고 다음과 같은 명령행으로 실행중이었습니다.

charset.exe -STESTDBM -I"C:\SAP\ini\sql.ini" -L"C:\SAP\charsets\cp850" charset.loc

그래서, 그냥 혹시나 하고 직접 실행해 보았습니다.

C:\SAP\ASE-16_0\bin>C:\SAP\ASE-16_0\bin\charset.exe -STESTDBM -I"C:\SAP\ini\sql.ini" -L"C:\SAP\charsets\cp850" charset.loc
Please enter SA Password : Loading file 'charset.loc'.

Character set (ID = 2) with NAME = 'cp850' already exists
in the Syscharsets system table.  Do you wish to update this character set
with the definitions found in your localization file for character set
(ID = 2, NAME = 'cp850')?
(yes/no):  y


Finished loading the Character Set Definition.

Finished loading file 'charset.loc'.

잘 끝났군요. ^^ 그래서 그냥 프로세스 관리자에서 현재 셋업 프로세스가 붙잡고 있는 charset.exe를 강제 종료했고 이후 설치가 잘 진행되었습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/11/2016]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13981정성태8/1/2025223오류 유형: 971. CentOS 7에서 yum 사용 시 "Could not resolve host: mirrorlist.centos.org; Unknown error"
13980정성태7/31/2025289Linux: 119. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ (2)
13979정성태7/30/2025301Linux: 118. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ
13978정성태7/29/2025415오류 유형: 970. 파일 복사 시 "Data error (cyclic redundancy check). (0x80070017)" 에러
13977정성태7/28/2025514닷넷: 2349. C# 14 - (5) 문자열 리터럴을 utf-8 인코딩으로 저장파일 다운로드1
13976정성태7/25/2025777닷넷: 2348. C# - 카카오 카나나 모델 + Microsoft.ML.OnnxRuntimeGenAI 예제파일 다운로드1
13975정성태7/23/2025913닷넷: 2347. C# 14 - (4) 형식 인자가 없는 제네릭 타입의 nameof 지원파일 다운로드1
13974정성태7/22/20251200닷넷: 2346. C# 14 - (3) Span 타입과 배열 간의 암시적 형변환파일 다운로드1
13973정성태7/21/20251068닷넷: 2345. C# - 배열 및 Span의 공변성파일 다운로드1
13972정성태7/21/20251320닷넷: 2344. C#의 Identity conversion 의미파일 다운로드1
13971정성태7/17/20251433닷넷: 2343. C# 14 - (2) 속성 구문에서 문맥 키워드로 추가되는 field 예약어파일 다운로드1
13970정성태7/17/20251387닷넷: 2342. C# 14 - (1) (예약)
13969정성태7/17/20251434닷넷: 2341. snap으로 설치한 .NET 리눅스 실행 환경
13968정성태7/16/20251315오류 유형: 969. lddtree - TypeError: 'type' object is not subscriptable
13967정성태7/16/20251842오류 유형: 968. snap으로 설치한 "dotnet run" 실행 시 "undefined symbol: _dl_audit_symbind_alt, version GLIBC_PRIVATE" 오류
13966정성태7/15/20252389디버깅 기술: 223. WinDbg - .kframes 명령어
13965정성태7/11/20251671오류 유형: 967. 디버깅 모드로 실행 시 "Could not find file 'C:\Program Files\IIS Express\Oracle.DataAccess.Common.Configuration.Section.xsd'" 예외
13964정성태7/10/20252337닷넷: 2340. C# - Win32 Multimedia Timer 주기파일 다운로드1
13963정성태7/8/20251879VS.NET IDE: 202. Visual Studio 2022 + Copilot 기본 사용법
13962정성태7/7/20251898스크립트: 79. 파이썬 - onnxruntime_genai에서 지원하지 않는 모델 사용
13961정성태7/5/20251604디버깅 기술: 222. WinDbg 분석 사례 - IISreset 시점에 w3wp.exe의 crash 발생
13960정성태7/3/20252788개발 환경 구성: 752. ProcDump - C/C++ 예외 코드 필터를 지정한 덤프 생성 [2]
13959정성태6/25/20251817오류 유형: 966. Ubuntu - ping: connect: Network is unreachable
13958정성태6/21/20252490닷넷: 2339. C# - Phi-4-multimodal 모델의 GPU 가속 방법 (ORT 사용)파일 다운로드1
13957정성태6/20/20252940닷넷: 2338. C# / Foundry Local - Phi-4-multimodal 모델을 사용하는 방법 [1]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...