我正在构建一个 .NET 断开连接的客户端-服务器应用程序,它使用 Entity Framework 5 (EF5) 从 POCO 生成 SQL Server CE 4.0 数据库。该应用程序允许用户将数据从网络 SQL Server 批量复制到客户端的 SQL Server CE 数据库中。由于 EF5 创建的约束和索引,这非常(非常)慢。临时删除约束和索引会将 30 分钟的等待时间减少到 1 分钟或更短。
在开始大容量复制之前,应用程序执行查询以从 SQL Server CE 表中删除约束和索引。但是,命令会失败,因为 EF5 创建的约束名称包括表架构名称、点和表名称。由于解析问题,约束名称中的点导致 drop 命令失败。
例如,POCO Customer
创建表 dbo.Customer
带有主键约束 PK_dbo.Customer_Id
.数据库按预期执行。
但是,在执行非查询时:
ALTER TABLE Customer DROP CONSTRAINT PK_dbo.Customer;
SQL Server Compact ADO.NET 数据提供程序返回错误:
There was an error parsing the query.
[ Token line number = 1, Token line offset = 57, Token in error = . ]
当然,使用辅助
DataContext
没有外键的对象生成没有约束的数据库,后面再添加即可;但是,这需要维护两个 DataContext
对象,希望不要忘记保持更新。因此,我正在寻找两种解决方案之一:预先感谢您的帮助!
最佳答案
将那个坏男孩包裹在 [] 中。它告诉解析器里面的所有东西都是键名。
ALTER TABLE Customer DROP CONSTRAINT [PK_dbo.Customer];
应该运行良好。
就我个人而言,我只是将每个标识符都用括号括起来以避免这个确切的问题。所以我会像这样写这个查询。
ALTER TABLE [Customer] DROP CONSTRAINT [PK_dbo.Customer];
我认为这样更易读,因为您可以立即看到标识符。
关于sql - EF5 使用名称中的点生成 SQL Server CE 约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18140219/