SQL Server CE与SqlClient

时间:2018-08-24 14:51:43

标签: sql-server sql-server-ce sqlclient

SqlServerCeSqlClient代码之间有什么区别? 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>

我希望摆脱SqlServerCeSqlClient,因为在我的配置中我没有理由同时使用这两个提供程序。

编辑:如果我将重点放在Azure驱动的数据库上,我应该选择哪个提供商? (本地或远程数据库需要其他提供程序)

1 个答案:

答案 0 :(得分:1)

SqlServerCe用于单用户单机SQL Server 精简版,Microsoft不再正式支持。

SqlClient是我们所熟知的完整,完整 SQL Server的提供程序-也是Azure数据库产品的基础。

EF 6肯定支持这两个提供程序。

如果要删除任何内容-务必删除SqlServerCe并保留真实,完整的SQL Server!但是从技术角度来看,这是两种非常不同的数据库技术,并且很可能在某些情况下您需要两者