EF4生成无效脚本

时间:2010-04-22 16:59:58

标签: visual-studio-2010 entity-framework-4

当我右键单击.EDMX文件并单击Generate Database From Model时,由于表名,生成的脚本显然是错误的。它生成的是以下脚本。请注意DROP TABLE部分与CREATE TABLE部分中的表名称。

为什么这不一致?

这显然不是可重复使用的脚本。我创建的是一个名为“Address”的实体和一个名为“Company”的实体等(所有单数)。 EntitySet名称是复数。 “Pluralize New Objects”布尔值也不会改变它。这是什么交易?

对于它的价值,我最初通过将EDMX指向具有非复数名称的表的数据库来生成EDMX,现在我已经做了一些更改,我想回到另一个方向。因为db-first和model-first模型在所有场景中都不是理想的,所以我希望可以选择前后移动。我可以控制以确保多个人都不会出现合并问题。方式同时。

-- --------------------------------------------------
-- Dropping existing FOREIGN KEY constraints
-- NOTE: if the constraint does not exist, an ignorable error will be reported.
-- --------------------------------------------------

    ALTER TABLE [Address] DROP CONSTRAINT [FK_Address_StateID-State_ID];
GO
    ALTER TABLE [Company] DROP CONSTRAINT [FK_Company_AddressID-Address_ID];
GO
    ALTER TABLE [Employee] DROP CONSTRAINT [FK_Employee_BossEmployeeID-Employee_ID];
GO
    ALTER TABLE [Employee] DROP CONSTRAINT [FK_Employee_CompanyID-Company_ID];
GO
    ALTER TABLE [Employee] DROP CONSTRAINT [FK_Employee_PersonID-Person_ID];
GO
    ALTER TABLE [Person] DROP CONSTRAINT [FK_Person_AddressID-Address_ID];
GO

-- --------------------------------------------------
-- Dropping existing tables
-- NOTE: if the table does not exist, an ignorable error will be reported.
-- --------------------------------------------------

    DROP TABLE [Address];
GO
    DROP TABLE [Company];
GO
    DROP TABLE [Employee];
GO
    DROP TABLE [Person];
GO
    DROP TABLE [State];
GO

-- --------------------------------------------------
-- Creating all tables
-- --------------------------------------------------

-- Creating table 'Addresses'
CREATE TABLE [Addresses] (
    [ID] int IDENTITY(1,1) NOT NULL,
    [StreetAddress] nvarchar(100)  NOT NULL,
    [City] nvarchar(100)  NOT NULL,
    [StateID] int  NOT NULL,
    [Zip] nvarchar(10)  NOT NULL
);
GO

-- Creating table 'Companies'
CREATE TABLE [Companies] (
    [ID] int IDENTITY(1,1) NOT NULL,
    [Name] nvarchar(100)  NOT NULL,
    [AddressID] int  NOT NULL
);
GO

-- Creating table 'People'
CREATE TABLE [People] (
    [ID] int IDENTITY(1,1) NOT NULL,
    [FirstName] nvarchar(100)  NOT NULL,
    [LastName] nvarchar(100)  NOT NULL,
    [AddressID] int  NOT NULL
);
GO

-- Creating table 'States'
CREATE TABLE [States] (
    [ID] int IDENTITY(1,1) NOT NULL,
    [Name] nvarchar(100)  NOT NULL,
    [Abbreviation] nvarchar(2)  NOT NULL
);
GO

-- Creating table 'Employees'
CREATE TABLE [Employees] (
    [ID] int IDENTITY(1,1) NOT NULL,
    [PersonID] int  NOT NULL,
    [CompanyID] int  NOT NULL,
    [Position] nvarchar(100)  NOT NULL,
    [BossEmployeeID] int  NULL
);
GO

-- --------------------------------------------------
-- Creating all PRIMARY KEY constraints
-- --------------------------------------------------

-- Creating primary key on [ID] in table 'Addresses'
ALTER TABLE [Addresses]
ADD CONSTRAINT [PK_Addresses]
    PRIMARY KEY ([ID] );
GO

-- Creating primary key on [ID] in table 'Companies'
ALTER TABLE [Companies]
ADD CONSTRAINT [PK_Companies]
    PRIMARY KEY ([ID] );
GO

-- Creating primary key on [ID] in table 'People'
ALTER TABLE [People]
ADD CONSTRAINT [PK_People]
    PRIMARY KEY ([ID] );
GO

-- Creating primary key on [ID] in table 'States'
ALTER TABLE [States]
ADD CONSTRAINT [PK_States]
    PRIMARY KEY ([ID] );
GO

-- Creating primary key on [ID] in table 'Employees'
ALTER TABLE [Employees]
ADD CONSTRAINT [PK_Employees]
    PRIMARY KEY ([ID] );
GO

-- --------------------------------------------------
-- Creating all FOREIGN KEY constraints
-- --------------------------------------------------

-- Creating foreign key on [StateID] in table 'Addresses'
ALTER TABLE [Addresses]
ADD CONSTRAINT [FK_Address_StateID_State_ID]
    FOREIGN KEY ([StateID])
    REFERENCES [States]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Address_StateID_State_ID'
CREATE INDEX [IX_FK_Address_StateID_State_ID]
ON [Addresses]
    ([StateID]);
GO

-- Creating foreign key on [AddressID] in table 'Companies'
ALTER TABLE [Companies]
ADD CONSTRAINT [FK_Company_AddressID_Address_ID]
    FOREIGN KEY ([AddressID])
    REFERENCES [Addresses]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Company_AddressID_Address_ID'
CREATE INDEX [IX_FK_Company_AddressID_Address_ID]
ON [Companies]
    ([AddressID]);
GO

-- Creating foreign key on [AddressID] in table 'People'
ALTER TABLE [People]
ADD CONSTRAINT [FK_Person_AddressID_Address_ID]
    FOREIGN KEY ([AddressID])
    REFERENCES [Addresses]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Person_AddressID_Address_ID'
CREATE INDEX [IX_FK_Person_AddressID_Address_ID]
ON [People]
    ([AddressID]);
GO

-- Creating foreign key on [CompanyID] in table 'Employees'
ALTER TABLE [Employees]
ADD CONSTRAINT [FK_Employee_CompanyID_Company_ID]
    FOREIGN KEY ([CompanyID])
    REFERENCES [Companies]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Employee_CompanyID_Company_ID'
CREATE INDEX [IX_FK_Employee_CompanyID_Company_ID]
ON [Employees]
    ([CompanyID]);
GO

-- Creating foreign key on [BossEmployeeID] in table 'Employees'
ALTER TABLE [Employees]
ADD CONSTRAINT [FK_Employee_BossEmployeeID_Employee_ID]
    FOREIGN KEY ([BossEmployeeID])
    REFERENCES [Employees]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Employee_BossEmployeeID_Employee_ID'
CREATE INDEX [IX_FK_Employee_BossEmployeeID_Employee_ID]
ON [Employees]
    ([BossEmployeeID]);
GO

-- Creating foreign key on [PersonID] in table 'Employees'
ALTER TABLE [Employees]
ADD CONSTRAINT [FK_Employee_PersonID_Person_ID]
    FOREIGN KEY ([PersonID])
    REFERENCES [People]
        ([ID])
    ON DELETE NO ACTION ON UPDATE NO ACTION;

-- Creating non-clustered index for FOREIGN KEY 'FK_Employee_PersonID_Person_ID'
CREATE INDEX [IX_FK_Employee_PersonID_Person_ID]
ON [Employees]
    ([PersonID]);
GO

-- --------------------------------------------------
-- Script has ended
-- --------------------------------------------------

1 个答案:

答案 0 :(得分:0)

我一直无法找到这个问题的答案。另外,我在重新解决这个问题时遇到了一些问题,我不会从数据库优先到模型优先的场景来回。因此,我只是假设来回引起了问题,并且让EF通过是一个糟糕的情况。