다음과 같은 문제가 내 NHibernate 일대 다 매핑에 있습니다. 모든 고객을 얻으려면 API 메소드를 통해 다음 오류가 발생합니다.Nhibernate "컬렉션을 초기화 할 수 없습니다"
"$id":"1","Message":"An error has occurred.","ExceptionMessage":"The 'ObjectContent`1' type failed to serialize the response body for content type 'text/html; charset=utf-8'.","ExceptionType":"System.InvalidOperationException","StackTrace":null,"InnerException":{"$id":"2","Message":"An error has occurred.","ExceptionMessage":"could not initialize a collection: [Designet.Models.Customer.Orders#1][SQL: SELECT orders0_.CustomerId as Custom2_2_1_, orders0_.Id as Id1_2_1_, orders0_.Id as Id1_2_0_, orders0_.CustomerId as Custom2_2_0_, orders0_.Description as Descri3_2_0_, orders0_.Price as Price4_2_0_, orders0_.Created as Create5_2_0_, orders0_.Deadline as Deadli6_2_0_ FROM Order orders0_ WHERE orders0_.CustomerId=?]","ExceptionType":"NHibernate.Exceptions.GenericADOException","StackTrace":" w NHibernate.Loader.Loader.LoadCollection(ISessionImplementor session, Object id, IType type)\r\n
아래 코드를 붙여 넣었습니다. 나는 구글과 내 문제에 대한 해답을 찾고 있었지만 아무것도 제안하지 않았다. 코드의 어느 부분에서 오류가 발생하는지 이해하지 못합니다. 어쩌면 문제를 해결하기 위해 내가해야 할 일이 무엇일까요? 나는 당신의 도움에 매우 기뻐할 것입니다.
고객 모델 :
public class Customer
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual IList<Order> Orders { get; set; }
public Customer()
{
Orders = new List<Order>();
}
}
고객 매핑 :
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="true"
assembly="Designet" namespace="Designet.Models">
<class name="Customer" table="Customer" dynamic-update="true" lazy="true" >
<cache usage="read-write"/>
<id name="Id" column="Id" type="int">
<generator class="native" />
</id>
<property name="Name" />
<bag name="Orders" lazy="true" inverse="true" >
<key column="CustomerId"/>
<one-to-many class="Designet.Models.Order"/>
</bag>
</class>
</hibernate-mapping>
고객 데이터베이스 :
CREATE TABLE [dbo].[Customer] (
[Id] INT IDENTITY (1, 1) NOT NULL,
[Name] NVARCHAR (255) NULL,
PRIMARY KEY CLUSTERED ([Id] ASC)
);
주문 모델 :
public class Order
{
public virtual int Id { get; set; }
public virtual string Description { get; set; }
public virtual decimal Price { get; set; }
public virtual DateTime Created { get; set; }
public virtual DateTime Deadline { get; set; }
public virtual int CustomerId { get; set; }
public virtual Customer Customer { get; set; }
}
주문 매핑 :
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" auto-import="true"
assembly="Designet" namespace="Designet.Models"
<class name="Order" table="Order" dynamic-update="true" lazy="true" >
<cache usage="read-write"/>
<id name="Id" column="Id" type="int">
<generator class="native" />
</id>
<many-to-one name="Customer" column="CustomerId"/>
<property name="Description" />
<property name="Price" />
<property name="Created" />
<property name="Deadline" />
<property name="CustomerId" not-null="true" />
</class>
</hibernate-mapping>
주문 데이터베이스 :
CREATE TABLE [dbo].[Order] (
[Id] INT IDENTITY (1, 1) NOT NULL,
[Description] NVARCHAR (MAX) NULL,
[Price] SMALLMONEY NULL,
[Created] DATETIME NOT NULL,
[Deadline] DATETIME NULL,
[CustomerId] INT NOT NULL,
PRIMARY KEY CLUSTERED ([Id] ASC),
FOREIGN KEY ([CustomerId]) REFERENCES [dbo].[Customer] ([Id])
);
'bag'을'set'으로,'IList <>'를'ISet <>'으로 바꾸었지만 도움이되지 않았습니다. 전체 오류가 있습니다 : http://www.jsoneditoronline.org/?id=48b540615c2550df97c1cafdb3550502 –
그리고 문제 해결에 대한 답변이 들어 있습니다. 답변이 수정되었습니다. –
이제 작품입니다. 고마워요! –