sql - EF5 使用名称中的点生成 SQL Server CE 约束

标签 sql entity-framework ef-code-first sql-server-ce poco

我正在构建一个 .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对象,希望不要忘记保持更新。因此,我正在寻找两种解决方案之一:
  • 以这样的方式编写 DROP 语句,使得 .字符被解析
  • 防止 EF5 使用 .约束和索引名称中的字符

  • 预先感谢您的帮助!

    最佳答案

    将那个坏男孩包裹在 [] 中。它告诉解析器里面的所有东西都是键名。

    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/

    相关文章:

    c# - 使用 Entity Framework 的最佳比较算法

    c# - 如何通过代码优先全局更改小数点的精度和小数位?

    c# - EF Code First DropCreateDatabase始终不执行

    sql - ORA-00936 : missing expression error when inserting values

    mysql - 检索除带有子查询的元组之外的所有元组

    sql - SQLite如何选择多列并按出现顺序返回它们

    MySQL - 根据最新日期和每列的 id 列表将行转换为列

    c# - 在 Entity Framework 中按日期划分实体

    entity-framework - 使用 dotconnect 在 Entity Framework 中启用级联删除

    entity-framework - Entity Framework 代码优先 - SQL 注入(inject)预防