2012-09-16 5 views
9

인터넷에서 많은 것을보고 난 후에과 .sdf의 두 파일 유형에 대한 설명을 찾지 못했습니다.언제 .mdf를 사용하고 언제 .sdf를 사용할 수 있습니까?

.sdf은 SQL Server의 컴팩트 버전 (.mdf)이라고 생각합니다. 여전히 그들은 완전히 다른 것처럼 보입니다.

msdn에 대한 두 개의 자습서 (예 : MVC Movie AppMusicstore)를 따랐습니다. 둘 다 .sdf을 사용하십시오.

부분 인용문 (full) : '우선, "DataDirectory | ASPNETDBContext.mdf"여야합니다 (확장자 차이점에 유의하십시오). 귀하의 APPLIC ... '

두 자습서 .sdf에 연결 문자열을, 즉 :

<add name    ="MovieDBContext" 
    connectionString ="Data Source=|DataDirectory|Movies.sdf" 
    providerName  ="System.Data.SqlServerCe.4.0" 
/> 

<add name    ="MusicStoreEntities" 
    connectionString ="Data Source=|DataDirectory|MvcMusicStore.sdf" 
    providerName  ="System.Data.SqlServerCe.4.0" 
/> 

질문 :

내 질문은 무엇을 어디에 사용할 때하는 것입니다? 이상을 사용하는 이유는입니다.

+2

[StackOverflow] (http://stackoverflow.com/questions/1175882/what-is-an-mdf-file) 자체에서 해당 답변을 찾을 수 있습니다. MDF - 중간 디스크 이미지 파일 & SDF - 표준 데이터 파일 –

+0

그리고 차이점은 무엇입니까? 그리고 언제 사용할 수 있습니까? 그 질문 외에 당신은 .mdf에 대해서만 이야기했습니다. sdf와의 유일한 차이점을 추측 (추측)하는 것이 파일 확장입니다. –

답변

13

일부 데이터 (작은 데이터 개수)를 저장하기 위해 Windows 전화에서 널리 사용되는 SQL Server Compact (sdf 파일)는 웹 사이트에서도 사용할 수 있지만 성능이 좋지 않습니다. SQLite도 더 좋습니다.

많은 양의 큰 사이트에서 SQL Server (mdf 파일)가 사용됩니다. 그것의 더 강력하지만, 휴대 전화에서 사용할 수없고 서버에 설치해야합니다.

이 봐 : Comparison of SQL Server Compact, SQL Server Express 2012 and LocalDB

12

SQL 서버 컴팩트 에디션 참으로 "일반"SQL 서버는 매우 다르다.

SQL Server CE는 코드가 실행되는 컴퓨터에서 응용 프로그램에 의해로드되는 독립 실행 형 단일 사용자 데이터베이스입니다. 하나의 단일 .sdf 파일에 모든 데이터가 있으며 "일반"SQL Server (및 그 기능)의 일부만 지원합니다. SQL Server CE는 전화 응용 프로그램과 같은 단순한 독립 실행 형 단일 사용자 응용 프로그램에 적합합니다.

"실제"SQL Server는 서버 제품입니다. 서버에이 클라이언트를 설치하면 해당 클라이언트 만 클라이언트에 연결됩니다. 일반적으로 클라이언트 컴퓨터에는 SQL Server 자체가 설치되어 있지 않습니다. 저장된 proc, 트리거 등 모든 것을 갖춘 본격적인 RDBMS이기 때문에 주문 처리, 청구서 작성, 회계, 여러 사용자가 사용할 수있는 대규모 데이터베이스와 같은 엔터프라이즈 응용 프로그램을 생각하는 구조화 된 대형 데이터를 처리하는 데 최적입니다. 종류.

0

먼저 SQL Server 데이터베이스 파일은 완전한 SQL 서버 데이터베이스가 아닙니다.이 형식으로 작성하는 경우 SQL Server Express입니다. 대부분의 호스트는 SQL Server Express를 실행하지 않기 때문에 Sql Server Express 데이터베이스는 사용하기 매우 환상적이지 않으며 SQL Server Express 데이터베이스를 SQL 서버 데이터베이스에서 실행하려고하면 문제가 발생합니다. 먼저 SQL Server로 시작한 후 표현 및 마이그레이션하는 것이 더 좋습니다.

로컬 db는 실제로 SQL Server Compact Edition입니다. http://en.wikipedia.org/wiki/SQL_Server_Compact

연결 문자열의 경우 http://www.connectionstrings.com/sql-server/ 거기에는 거의 모든 연결 문자열이 있습니다.SQL Server Express를 사용하려면 SQL Server Express를 설치하고 관리해야합니다. SQL Server Express 관리 도구를 다운로드해야합니다. 일반적으로 대부분의 SQL Express 인스턴스는 로컬 계정과 함께 사용하도록 설계되었지만 올바르게 기억한다면 관리 도구를 사용하여 SQL Server 로그인을 생성 할 수 있습니다.