首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SqlConnection DBConnection Windowsce

SqlConnection DBConnection Windowsce
EN

Stack Overflow用户
提问于 2013-04-19 18:20:12
回答 1查看 1.4K关注 0票数 1

我在Windows CE 5.0下用Compact Framework3.5编写这段代码,以处理两个不同的数据库:

代码语言:javascript
复制
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlServerCe;
using System.Data.Common;

public myClass
{
    private DbConnection dbCn;
    private DbCommand dbCmd;
    public void myClass(bool ce)
    {
        if (ce)
        {
            dbCn = new SqlCeConnection();
            dbCmd = new SqlCeCommand();
        }
        else
        {
            dbCn = new SqlConnection(); // COMPILER ERROR Cannot implicitly convert type 'System.Data.SqlClient.SqlConnection' to 'System.Data.Common.DbConnection'
            dbCmd = new SqlCommand();// COMPILER ERROR Cannot implicitly convert type 'System.Data.SqlClient.SqlCommand' to 'System.Data.Common.DbCommand'  
        }
    }

为什么无法将SqlXX转换为DbXX?来自MSDN SqlXX的是DbXX!顺便说一句,SqlCeXX没有问题。我不能使用cf中缺少的DbPoviderfactory。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-19 20:24:21

你正在尝试做的是Covariance and Contravariance in Generics,但是直到.NET 4.0才出现。

更新似乎从[DbConnection][SqlConnection]的转换可能会省略一些参数,所以微软不允许简单的转换。

如果你真的想做到这一点,请查看这个帖子,看看如何编写代码:

C# DbConnection cast to SqlConnection

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16102400

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档