Microsoft MVP성태의 닷넷 이야기
오류 유형: 31. SQL Compact Edition 설치 후 오류 [링크 복사], [링크+제목 복사],
조회: 19452
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  103  [104]  105  ...
NoWriterDateCnt.TitleFile(s)
11325정성태10/14/201719348.NET Framework: 689. CLR 4.0 환경에서 DLL 모듈의 로드 주소(Base address) 알아내는 방법
11324정성태10/13/201720949디버깅 기술: 101. windbg - "*** WARNING: Unable to verify checksum for" 경고 없애는 방법
11322정성태10/13/201718346디버깅 기술: 100. windbg - .NET 4.0 응용 프로그램의 Main 메서드에 Breakpoint 걸기
11321정성태10/11/201719850.NET Framework: 688. NGen 모듈과 .NET Profiler
11320정성태10/11/201720633.NET Framework: 687. COR_PRF_USE_PROFILE_IMAGES 옵션과 NGen의 "profiler-enhanced images" [1]
11319정성태10/11/201728179.NET Framework: 686. C# - string 배열을 담은 구조체를 직렬화하는 방법
11318정성태10/7/201720967VS.NET IDE: 122. 비주얼 스튜디오에서 관리자 권한을 요구하는 C# 콘솔 프로그램 제작 [1]
11317정성태10/4/201726146VC++: 120. std::copy 등의 함수 사용 시 _SCL_SECURE_NO_WARNINGS 에러 발생
11316정성태9/30/201724189디버깅 기술: 99. (닷넷) 프로세스(EXE)에 디버거가 연결되어 있는지 아는 방법 [4]
11315정성태9/29/201740244기타: 68. "시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지" 구매하신 분들을 위한 C# 7.0/7.1 추가 문법 PDF [8]
11314정성태9/28/201722050디버깅 기술: 98. windbg - 덤프 파일로부터 닷넷 버전 확인하는 방법
11313정성태9/25/201719319디버깅 기술: 97. windbg - 메모리 덤프로부터 DateTime 형식의 값을 알아내는 방법파일 다운로드1
11312정성태9/25/201722454.NET Framework: 685. C# - 구조체(값 형식)의 필드를 리플렉션을 이용해 값을 바꾸는 방법파일 다운로드1
11311정성태9/20/201716846.NET Framework: 684. System.Diagnostics.Process 객체의 명시적인 해제 권장
11310정성태9/19/201720294.NET Framework: 683. WPF의 Window 객체를 생성했는데 GC 수집 대상이 안 되는 이유 [3]
11309정성태9/13/201718414개발 환경 구성: 335. Octave의 명령 창에서 실행한 결과를 복사하는 방법
11308정성태9/13/201719459VS.NET IDE: 121. 비주얼 스튜디오에서 일부 텍스트 파일을 무조건 메모장으로만 여는 문제파일 다운로드1
11307정성태9/13/201722005오류 유형: 421. System.Runtime.InteropServices.SEHException - 0x80004005
11306정성태9/12/201720098.NET Framework: 682. 아웃룩 사용자를 위한 중국어 스팸 필터 Add-in
11305정성태9/12/201721567개발 환경 구성: 334. 기존 프로젝트를 Visual Studio를 이용해 Github의 신규 생성된 repo에 올리는 방법 [1]
11304정성태9/11/201718672개발 환경 구성: 333. 3ds Max를 Hyper-V VM에서 실행하는 방법
11303정성태9/11/201721983개발 환경 구성: 332. Inno Setup 파일의 관리자 권한을 제거하는 방법
11302정성태9/11/201718238개발 환경 구성: 331. SQL Server Express를 위한 방화벽 설정
11301정성태9/11/201717108오류 유형: 420. SQL Server Express 연결 오류 - A network-related or instance-specific error occurred while establishing a connection to SQL Server.
11300정성태9/10/201720990.NET Framework: 681. dotnet.exe - run, exec, build, restore, publish 차이점 [3]
11299정성태9/9/201719715개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
... 91  92  93  94  95  96  97  98  99  100  101  102  103  [104]  105  ...