私は冬眠の世界に不慣れです。ばかげた質問かもしれませんが、私はそれを解決することができません。私はテーブルの多対多の関係をテストし、レコードを挿入しようとしています。DepartmentテーブルとEmployeeテーブルがあります。ここでは、従業員と部門が1対1の関係にあります。FluentNHibernateを使用してレコードを追加しています。以下のすべてのコード。plsヘルプ
SQLコード
create table Dept (
Id int primary key identity,
DeptName varchar(20),
DeptLocation varchar(20)
);
create table Employee (
Id int primary key identity,
EmpName varchar(20),
EmpAge int,
DeptId int references Dept(Id)
);
クラスファイル
public partial class Dept
{
public virtual System.String DeptLocation { get; set; }
public virtual System.String DeptName { get; set; }
public virtual System.Int32 Id { get; private set; }
public virtual IList<Employee> Employees { get; set; }
}
public partial class Employee
{
public virtual System.Int32 DeptId { get; set; }
public virtual System.Int32 EmpAge { get; set; }
public virtual System.String EmpName { get; set; }
public virtual System.Int32 Id { get; private set; }
public virtual Project.Model.Dept Dept { get; set; }
}
マッピングファイル
public class DeptMapping : ClassMap<Dept>
{
public DeptMapping()
{
Id(x => x.Id);
Map(x => x.DeptName);
Map(x => x.DeptLocation);
HasMany(x => x.Employees).Inverse().Cascade.All();
}
}
public class EmployeeMapping : ClassMap<Employee>
{
public EmployeeMapping()
{
Id(x => x.Id);
Map(x => x.EmpName);
Map(x => x.EmpAge);
Map(x => x.DeptId);
References(x => x.Dept).Cascade.None();
}
}
追加するマイコード
try
{
Dept dept = new Dept();
dept.DeptLocation = "Austin";
dept.DeptName = "Store";
Employee emp = new Employee();
emp.EmpName = "Ron";
emp.EmpAge = 30;
IList<Employee> empList = new List<Employee>();
empList.Add(emp);
dept.Employees = empList;
emp.Dept = dept;
IRepository<Dept> rDept = new Repository<Dept>();
rDept.SaveOrUpdate(dept);
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
ここで私はエラーが発生しています
InnerException ={"無効な列名'Dept_id'。"}メッセージ="挿入できませんでした:[Project.Model.Employee] [SQL:INSERT INTO [Employee](EmpName、EmpAge、DeptId、Dept_id)VALUES(?、?、 ?、?); select SCOPE_IDENTITY()] "