当前位置:  开发笔记 > 编程语言 > 正文

这是LINQ-to-SQL的一个例子吗?

如何解决《这是LINQ-to-SQL的一个例子吗?》经验,为你挑选了2个好方法。

我用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;
    }

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

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

}

Jon Skeet.. 5

是的,这是LINQ to SQL.它正在使用System.Data.Linq.DataContext,这是LINQ to SQL.听起来设计师不支持您的提供程序,但LINQ to SQL本身也是如此.

(或者设计师对你的连接字符串很挑剔,并且如果你稍微改变它就会应对.这听起来像任何东西......)



1> Jon Skeet..:

是的,这是LINQ to SQL.它正在使用System.Data.Linq.DataContext,这是LINQ to SQL.听起来设计师不支持您的提供程序,但LINQ to SQL本身也是如此.

(或者设计师对你的连接字符串很挑剔,并且如果你稍微改变它就会应对.这听起来像任何东西......)



2> Eric Petroel..:

这篇msdn文章指出,虽然LINQ to SQL运行时支持sdf,但设计人员不支持它.

报价:

LINQ to SQL运行时和SQLMetal命令行工具支持SQL Server Compact 3.5.

对象关系设计器不支持SQL Server Compact 3.5.

推荐阅读
sx-March23
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有