SqlServerCe
和SqlClient
代码之间有什么区别? EF代码首先需要SqlServerCe
,还是可以SqlClient
?如果我在本地数据库上运行,应该选择什么提供商?
我的app.config
如下:
<entityFramework>
<defaultConnectionFactory
type="System.Data.Entity.Infrastructure.SqlCeConnectionFactory, EntityFramework">
<parameters>
<parameter value="System.Data.SqlServerCe.4.0" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="System.Data.SqlClient"
type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
<provider invariantName="System.Data.SqlServerCe.4.0"
type="System.Data.Entity.SqlServerCompact.SqlCeProviderServices, EntityFramework.SqlServerCompact" />
<provider invariantName="System.Data.SQLite.EF6"
type="System.Data.SQLite.EF6.SQLiteProviderServices, System.Data.SQLite.EF6" />
</providers>
</entityFramework>
<DbProviderFactories>
<remove invariant="System.Data.SqlServerCe.4.0" />
<add name="Microsoft SQL Server Compact Data Provider 4.0"
invariant="System.Data.SqlServerCe.4.0"
description=".NET Framework Data Provider for Microsoft SQL Server Compact"
type="System.Data.SqlServerCe.SqlCeProviderFactory, System.Data.SqlServerCe, Version=4.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" />
<remove invariant="System.Data.SQLite.EF6" />
<add name="SQLite Data Provider (Entity Framework 6)"
invariant="System.Data.SQLite.EF6"
description=".NET Framework Data Provider for SQLite (Entity Framework 6)"
type="System.Data.SQLite.EF6.SQLiteProviderFactory, System.Data.SQLite.EF6" />
<remove invariant="System.Data.SQLite" />
<add name="SQLite Data Provider"
invariant="System.Data.SQLite"
description=".NET Framework Data Provider for SQLite"
type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite" />
</DbProviderFactories>
我希望摆脱SqlServerCe
或SqlClient
,因为在我的配置中我没有理由同时使用这两个提供程序。
编辑:如果我将重点放在Azure驱动的数据库上,我应该选择哪个提供商? (本地或远程数据库需要其他提供程序)
答案 0 :(得分:1)
SqlServerCe
用于单用户单机SQL Server 精简版,Microsoft不再正式支持。
SqlClient
是我们所熟知的完整,完整 SQL Server的提供程序-也是Azure数据库产品的基础。
EF 6肯定支持这两个提供程序。
如果要删除任何内容-务必删除SqlServerCe
并保留真实,完整的SQL Server!但是从技术角度来看,这是两种非常不同的数据库技术,并且很可能在某些情况下您需要两者