SQL Compact Edition 설치 후 오류
이번에는, SQL Server Compact Edition 을 설치한 경우에 발생할 수 있는 오류 현상에 대해서 설명해 보겠습니다. 일단, 경험으로 봐서는 단독 설치한 경우에는 발생하지 않고 SQL Server(Express)버전과 함께 설치되었을 때 발생하는 것 같습니다.
오류의 정확한 원인은 일단 다음에 살펴 보기로 하고, 임시로 문제를 해결할 수 있는 방법만을 설명드리겠습니다.
우선, 어떤 오류 현상들을 볼 수 있는지 나열해 보겠습니다.
1. SQL Server Management Studio Express 에서 DB 를 생성하고, 관련 DB 에 테이블을 생성하려 할 때 다음과 같은 오류가 발생합니다.
"
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 를 등록하려 할때 다음과 같은 오류창이 뜨게 됩니다.
이를 해결하기 위해서는 위의 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 시켜야 할지도 아직은 명확하게 정리가 안되었습니다.
어쨌든 일단, 오늘은 여기까지만. ^^
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]