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)
13990정성태8/8/20252424Windows: 283. Time zone 설정이 없는 Windows Server 2025
13989정성태8/8/20253459닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
13988정성태8/8/20253360오류 유형: 974. 비주얼 스튜디오 업데이트 시 잠김 파일 경고 - Visual Studio Standard Collector Service 150 (VSStandardCollectorService150)
13987정성태8/7/20252885닷넷: 2351. C# 14 - (6) event와 생성자에도 partial 메서드 적용파일 다운로드1
13986정성태8/6/20252457닷넷: 2350. C# 14 - (5) 람다 매개 변수에 접근자가 있는 경우에도 타입 생략 가능파일 다운로드1
13985정성태8/6/20253176오류 유형: 973. "wsl --install" 명령어 수행 시 "The server name or address could not be resolved"
13984정성태8/6/20252870Windows: 282. 윈도우 운영체제에 추가된 ssh 서버(Win32-OpenSSH)
13983정성태8/4/20252751오류 유형: 972. Microsoft.Data.SqlClient 6.1.0 버전부터 .NET 8 이상만 지원
13982정성태8/2/20253072개발 환경 구성: 753. CentOS 7 컨테이너 내에서 openssh 서버 호스팅
13981정성태8/1/20252631오류 유형: 971. CentOS 7에서 yum 사용 시 "Could not resolve host: mirrorlist.centos.org; Unknown error"
13980정성태7/31/20252779Linux: 119. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ (2)
13979정성태7/30/20253341Linux: 118. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ
13978정성태7/29/20252684오류 유형: 970. 파일 복사 시 "Data error (cyclic redundancy check). (0x80070017)" 에러
13977정성태7/28/20253186닷넷: 2349. C# 14 - (4) 문자열 리터럴을 utf-8 인코딩으로 저장파일 다운로드1
13976정성태7/25/20252982닷넷: 2348. C# - 카카오 카나나 모델 + Microsoft.ML.OnnxRuntimeGenAI 예제파일 다운로드1
13975정성태7/23/20252876닷넷: 2347. C# 14 - (3) 형식 인자가 없는 제네릭 타입의 nameof 지원파일 다운로드1
13974정성태7/22/20253090닷넷: 2346. C# 14 - (2) Span 타입과 배열 간의 암시적 형변환파일 다운로드1
13973정성태7/21/20253242닷넷: 2345. C# - 배열 및 Span의 공변성파일 다운로드1
13972정성태7/21/20252887닷넷: 2344. C#의 Identity conversion 의미파일 다운로드1
13971정성태7/17/20253112닷넷: 2343. C# 14 - (1) 속성 구문에서 문맥 키워드로 추가되는 field 예약어파일 다운로드1
13970정성태7/17/20252803닷넷: 2342. C# 14 - (취소된 글)
13969정성태7/17/20252779닷넷: 2341. snap으로 설치한 .NET 리눅스 실행 환경
13968정성태7/16/20252794오류 유형: 969. lddtree - TypeError: 'type' object is not subscriptable
13967정성태7/16/20253590오류 유형: 968. snap으로 설치한 "dotnet run" 실행 시 "undefined symbol: _dl_audit_symbind_alt, version GLIBC_PRIVATE" 오류
13966정성태7/15/20254208디버깅 기술: 223. WinDbg - .kframes 명령어
13965정성태7/11/20253316오류 유형: 967. 디버깅 모드로 실행 시 "Could not find file 'C:\Program Files\IIS Express\Oracle.DataAccess.Common.Configuration.Section.xsd'" 예외
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...