我用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;
}
}
答案 0 :(得分:5)
是的,这是LINQ to SQL。它使用的是System.Data.Linq.DataContext
,它是LINQ to SQL。听起来 designer 不支持您的提供程序,但LINQ to SQL本身也支持。
(或者设计师对你的连接字符串很挑剔,并且如果你稍微改变它就会应对。这听起来像任何东西......)
答案 1 :(得分:5)
This msdn article注意到虽然LINQ to SQL运行时支持sdf,但设计者不支持它。
引用: