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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  [101]  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11501정성태4/17/201823250개발 환경 구성: 369. New-AzureRmADServicePrincipal로 생성한 계정의 clientSecret, key 값을 구하는 방법파일 다운로드1
11500정성태4/17/201824251개발 환경 구성: 368. PowerShell로 접근하는 Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11499정성태4/17/201822273개발 환경 구성: 367. Azure - New-AzureRmADServicePrincipal / New-AzureRmRoleAssignment 명령어
11498정성태4/17/201822343개발 환경 구성: 366. Azure Active Directory(Microsoft Enfra ID)의 사용자 유형 구분 - Guest/Member
11497정성태4/17/201819846개발 환경 구성: 365. Azure 리소스의 액세스 제어(Access control) 별로 사용자에게 권한을 할당하는 방법 [2]
11496정성태4/17/201820772개발 환경 구성: 364. Azure Portal에서 구독(Subscriptions) 메뉴가 보이지 않는 경우
11495정성태4/16/201821721개발 환경 구성: 363. Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11494정성태4/16/201817661개발 환경 구성: 362. Azure Web Apps(App Services)에 사용자 DNS를 지정하는 방법
11493정성태4/16/201819439개발 환경 구성: 361. Azure Web App(App Service)의 HTTP/2 프로토콜 지원
11492정성태4/13/201817922개발 환경 구성: 360. Azure Active Directory의 사용자 도메인 지정 방법
11491정성태4/13/201821212개발 환경 구성: 359. Azure 가상 머신에 Web Application을 배포하는 방법
11490정성태4/12/201820039.NET Framework: 739. .NET Framework 4.7.1의 새 기능 - Configuration builders [1]파일 다운로드1
11489정성태4/12/201817891오류 유형: 463. 윈도우 백업 오류 - a Volume Shadow Copy Service operation failed.
11488정성태4/12/201822450오류 유형: 462. Unhandled Exception in Managed Code Snap-in - FX:{811FD892-5EB4-4E73-A147-F1E079E36C4E}
11487정성태4/12/201819570디버깅 기술: 115. windbg - 닷넷 메모리 덤프에서 정적(static) 필드 값을 조사하는 방법
11486정성태4/11/201818560오류 유형: 461. Error MSB4064 The "ComputeOutputOnly" parameter is not supported by the "VsTsc" task
11485정성태4/11/201827631.NET Framework: 738. C# - Console 프로그램이 Ctrl+C 종료 시점을 감지하는 방법파일 다운로드1
11484정성태4/11/201829295.NET Framework: 737. C# - async를 Task 타입이 아닌 사용자 정의 타입에 적용하는 방법파일 다운로드1
11483정성태4/10/201832844개발 환경 구성: 358. "Let's Encrypt"에서 제공하는 무료 SSL 인증서를 IIS에 적용하는 방법 (2) [1]
11482정성태4/10/201824114VC++: 126. CUDA Core 수를 알아내는 방법
11481정성태4/10/201836909개발 환경 구성: 357. CUDA의 인덱싱 관련 용어 - blockIdx, threadIdx, blockDim, gridDim
11480정성태4/9/201826671.NET Framework: 736. C# - API를 사용해 Azure에 접근하는 방법 [2]파일 다운로드1
11479정성태4/9/201820613.NET Framework: 735. Azure - PowerShell로 Access control(IAM)에 새로운 계정 만드는 방법
11478정성태11/8/201924533디버깅 기술: 115. windbg - 덤프 파일로부터 PID와 환경변수 등의 정보를 구하는 방법 [1]
11477정성태4/8/201821043오류 유형: 460. windbg - sos 명령어 수행 시 c0000006 오류 발생
11476정성태4/8/201822450디버깅 기술: 114. windbg - !threads 출력 결과로부터 닷넷 관리 스레드(System.Threading.Thread) 객체를 구하는 방법
... 91  92  93  94  95  96  97  98  99  100  [101]  102  103  104  105  ...