Microsoft MVP성태의 닷넷 이야기
오류 유형: 31. SQL Compact Edition 설치 후 오류 [링크 복사], [링크+제목 복사],
조회: 19480
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


SQL Compact Edition 설치 후 오류


이번에는, SQL Server Compact Edition 을 설치한 경우에 발생할 수 있는 오류 현상에 대해서 설명해 보겠습니다. 일단, 경험으로 봐서는 단독 설치한 경우에는 발생하지 않고 SQL Server(Express)버전과 함께 설치되었을 때 발생하는 것 같습니다.

오류의 정확한 원인은 일단 다음에 살펴 보기로 하고, 임시로 문제를 해결할 수 있는 방법만을 설명드리겠습니다.

우선, 어떤 오류 현상들을 볼 수 있는지 나열해 보겠습니다.

1. SQL Server Management Studio Express 에서 DB 를 생성하고, 관련 DB 에 테이블을 생성하려 할 때 다음과 같은 오류가 발생합니다.

sql_ce_error_1.PNG

"
Exception has been thrown by the target of an invocation. (Microsoft.SqlServer.Express.SQLEditors)

Additional informations
 - An error occurred createing the configuration section handler for system.data:
   Column 'InvariantName' is constrained to be unique.
   Value 'Microsoft.SqlServerCe.Client' is already present.
   (C:\Windows\Microsoft.nET\Framework\v2.0.50727\Config\machine.config line 128)
   (System.Configuration)
    - Column 'InvariantName' is constrained to be unique.
      Value 'Microsoft.SqlServerCe.Client' is already present. (System.Data)
"

2. Visual Studio.NET 의 "Server Explorer"를 이용해서 새로운 DB 를 등록하려 할때 다음과 같은 오류창이 뜨게 됩니다.

sql_ce_error_2.PNG




이를 해결하기 위해서는 위의 1번 현상에서 보았던 경로의 "machine.config" 파일을 열어서 다음의 라인을 주석처리해야만 됩니다.

  <system.data>
    <DbProviderFactories>
      <add name="Odbc Data Provider" ... PublicKeyToken=b77a5c561934e089" />
      <add name="OleDb Data Provider" ... PublicKeyToken=b77a5c561934e089" />
      <add name="OracleClient Data Provider" ... PublicKeyToken=b77a5c561934e089" />
      <add name="SqlClient Data Provider" ... PublicKeyToken=b77a5c561934e089" />
      <!--add name="SQL Server CE Data Provider" 
      invariant="Microsoft.SqlServerCe.Client" 
      description=".NET Framework Data Provider for Microsoft SQL Server 2005 Mobile Edition" 
      type="Microsoft.SqlServerCe.Client.SqlCeClientFactory, Microsoft.SqlServerCe.Client, 
      Version=9.0.242.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" /-->
      <add name="SQL Server Compact Edition Data Provider" ... PublicKeyToken=89845dcd8080cc91" />
      <add name="SQL Server Compact Edition Client Data Provider" ... PublicKeyToken=89845dcd8080cc91" />
    </DbProviderFactories>
  </system.data>

물론, 이렇게 하면, Compact Edition 동작 관련해서는 분명히 오류가 발생할 것입니다. 해보진 않았지만, 어쩌면 상황에 따라서 서로의 provider 를 토글식으로 enable/disable 시켜야 할지도 아직은 명확하게 정리가 안되었습니다.

어쨌든 일단, 오늘은 여기까지만. ^^




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







[최초 등록일: ]
[최종 수정일: 3/18/2007]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11175정성태4/5/201725923.NET Framework: 652. C# 개발자를 위한 C++ COM 객체의 기본 구현 방식 설명파일 다운로드1
11174정성태4/3/201719451VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201722998VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
11172정성태4/3/201722160.NET Framework: 651. C# - 특정 EXE 프로세스를 종료시킨 EXE를 찾아내는 방법파일 다운로드1
11171정성태3/31/201718869VS.NET IDE: 114. Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...
11170정성태3/31/201720748.NET Framework: 650. C# - CachedAnonymousMethodDelegate 유형의 코드 생성
11169정성태3/30/201720615VC++: 114. C++ vtable의 가상 함수 호출 가로채기파일 다운로드1
11168정성태3/29/201723933VC++: 113. C++ 클래스 상속 관계의 vtable 생성 과정
11167정성태3/28/201724256VC++: 112. C++의 가상 함수 테이블 (vtable)은 언제 생성될까요? [2]
11166정성태3/28/201718484오류 유형: 382. System.Data.SqlClient.SqlException - Arithmetic overflow error converting IDENTITY to data type int.
11165정성태3/27/201721759오류 유형: 381. Visual C++에서 min, max 함수를 사용한 경우 C2589, C2059 컴파일 오류 발생
11164정성태3/27/201730099VC++: 111. C++ 클래스의 상속에 따른 메모리 구조 [2]파일 다운로드1
11163정성태3/25/201719894VC++: 110. CreateThread Win32 API에 C++ 클래스의 멤버 함수를 전달하는 방법파일 다운로드1
11162정성태3/24/201724118오류 유형: 380. Visual Studio 빌드 실패 - The OutputPath property is not set for project
11161정성태3/24/201716826오류 유형: 379. ICOMAdminCatalog.GetCollection 호출 시 0x80070422 예외 발생
11160정성태3/23/201721726.NET Framework: 649. ASP.NET - Server cannot append header after HTTP headers have been sent. (HTTP 헤더를 보낸 후에는 서버에서 헤더를 추가할 수 없습니다.)파일 다운로드1
11159정성태3/23/201719035Windows: 136. Memory-mapped File은 Private Bytes 크기에 포함될까요?파일 다운로드1
11158정성태3/22/201718642디버깅 기술: 85. Windbg - SOS 디버깅 사례 System.NullReferenceException 예외 추적
11157정성태3/22/201721903.NET Framework: 648. Dictionary<TKey, TValue>를 deep copy하는 방법파일 다운로드1
11156정성태3/21/201722537.NET Framework: 647. 닷넷(C#) 코드로 인증서 요청 코드 만드는 방법파일 다운로드1
11155정성태3/21/201722786.NET Framework: 646. SslStream의 CipherAlgorithm 선택이 가능할까요?파일 다운로드1
11154정성태3/5/201729771VC++: 109. DLL에서 STL 객체를 인자/반환값으로 갖는 함수를 제공할 때, 그 함수를 외부에서 사용하는 경우 비정상 종료한다면? [2]파일 다운로드1
11153정성태3/5/201729144VC++: 108. DLL에 정의된 C++ template 클래스의 복사 생성자 문제파일 다운로드1
11152정성태3/4/201722829VC++: 107. VirtualAlloc, HeapAlloc, GlobalAlloc, LocalAlloc, malloc, new의 차이점파일 다운로드1
11151정성태3/3/201723399VC++: 106. DLL 개발자가 주의해야 할 Secure CRT 함수 사용 [1]파일 다운로드1
11150정성태2/21/201719334.NET Framework: 645. Visual Studio Fakes 기능에서 Shim... 클래스가 생성되지 않는 경우 [5]
... 106  107  108  109  [110]  111  112  113  114  115  116  117  118  119  120  ...