我是NHibernate的新手,所以这可能是我的错误,但是当我使用时:
schema.Create(true, true);
我明白了:
SchemaExport [(null)]- There is already an object named 'XXX' in the database.
System.Data.SqlClient.SqlException: There is already an object
named 'XXX' in the database.
我抓住了nHibernate正在使用的SQL代码,直接从MSSMS运行它,并收到了类似的错误。调查一下,生成的代码没有正确地删除外键约束。下降看起来像这样:
if exists (select 1 from sysobjects where id = OBJECT_ID(N'dbo[FK22212EAFBFE4C58]')
AND parent_obj = OBJECT_ID('YYY'))
alter table dbo.YYY drop constraint FK22212EAFBFE4C58
做一个“选择OBJECT_ID(N'dbo [FK22212EAFBFE4C58]')”我得到了空。如果我取出“dbo”(即“选择OBJECT_ID(N'[FK22212EAFBFE4C58]')”),则返回ID。
所以,我的问题是,为什么nHibernate添加dbo,为什么这会阻止返回对象(因为拥有约束的表是dbo.XXX)
我的一个映射文件:
<?xml version="1.0" encoding="utf-8"?>
<hibernate-mapping namespace="CanineApp.Model" assembly="CanineApp.Model" xmlns="urn:nhibernate-mapping-2.2">
<class name="MedicalLog" table="MedicalLog" schema="dbo">
<id name="MedicalLogID" type="Int64">
<generator class="identity" />
</id>
<property name="InvoiceAmount" type="Decimal" not-null="true" />
...
<many-to-one name="Canine" class="Canine" column="CanineID" not-null="true" fetch="join" />
<many-to-one name="TreatmentCategory" class="TreatmentCategory" column="TreatmentCategoryID" not-null="true" access="field.camelcase-underscore" />
</class>
</hibernate-mapping>
答案 0 :(得分:0)
答案:。 这可能是一个错误。这个确切的issue for SQL Server 2005有一个条目。它似乎没有被标记为SQL 2000,因此我将创建一个错误报告或修复它。