【问题标题】:Is this an example of LINQ-to-SQL?这是 LINQ-to-SQL 的示例吗?
【发布时间】:2009-02-25 13:20:56
【问题描述】:

我用 SQL CE 数据库制作了一个小型 WPF 应用程序。

我使用 LINQ 构建了以下代码来从数据库中获取数据,这非常简单。所以我想“这一定是 LINQ-to-SQL”。

然后我做了“添加项目”并添加了一个“LINQ-to-SQL 类”.dbml 文件,将我的表拖到对象关系设计器上,但它说,“所选对象使用了不受支持的数据提供程序。”

然后我质疑以下代码是否真的是 LINQ-to-SQL,因为它确实允许我访问我的 SQL CE 数据库文件中的数据,但官方似乎不支持“LINQ-to-SQL” SQL CE。

那么下面的“LINQ-to-SQL”是不是?

using System.Linq;
using System.Data.Linq;
using System.Data.Linq.Mapping;
using System.Windows;

namespace TestLinq22
{
    public partial class Window1 : Window
    {
        public Window1()
        {
            InitializeComponent();

            MainDB db = new MainDB(@"Data Source=App_Data\Main.sdf");
            var customers = from c in db.Customers
                            select new {c.FirstName, c.LastName};
            TheListBox.ItemsSource = customers;
        }
    }

    [Database(Name = "MainDB")]
    public class MainDB : DataContext
    {
        public MainDB(string connection) : base(connection) { }
        public Table<Customers> Customers;
    }

    [Table(Name = "Customers")]
    public class Customers
    {
        [Column(DbType = "varchar(100)")]
        public string FirstName;

        [Column(DbType = "varchar(100)")]
        public string LastName;
    }

}

【问题讨论】:

    标签: c# linq-to-sql sql-server-ce


    【解决方案1】:

    This msdn article 指出,虽然 LINQ to SQL 运行时支持 sdf,但设计器不支持它。

    引用:

    • LINQ to SQL 运行时和 SQLMetal 命令行工具支持 SQL Server Compact 3.5。
    • 对象关系设计器不支持 SQL Server Compact 3.5。

    【讨论】:

      【解决方案2】:

      是的,那是 LINQ to SQL。它使用System.Data.Linq.DataContext,这是LINQ to SQL。听起来 设计器 不支持您的提供程序,但 LINQ to SQL 本身支持。

      (或者设计师对你的连接字符串很挑剔,如果你稍微改变一下就会应付。这听起来很可能......)

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-04-03
        • 1970-01-01
        • 1970-01-01
        • 2020-10-31
        相关资源
        最近更新 更多