所以,我遇到了FluentNHibernate的問題。我已經映射的所有特性,我聯繫我的表,我得到一個錯誤:FluentNHibernate:創建SessionFactory時使用了無效或不完整的配置
An invalid or incomplete configuration was used creating a SessionFactory. Check PotentialReasons collection, and InnerException for more detail.
不能確定究竟是什麼問題,因爲我創建的映射,類和基於以前的程序數據庫。在這裏我創建了一個SessionFactory的數據層類是:
namespace WTF.Edit1
{
public class DataLayer
{
private static ISessionFactory _factory = null;
private static object objLock = new object();
public static ISession GetSession()
{
if (_factory == null)
{
lock (objLock)
{
if (_factory == null)
_factory = CreateSessionFactory();
}
}
return _factory.OpenSession();
}
//konfiguracija i kreiranje session factory
private static ISessionFactory CreateSessionFactory()
{
try
{
var cfg = OracleManagedDataClientConfiguration.Oracle10
.ConnectionString(c =>
c.Is("Data Source=datasource:1111/AAAA;User Id=user;Password=pass"));
return Fluently.Configure()
.Database(cfg)
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<KorisnikMapiranja>())
.BuildSessionFactory();
}
catch (Exception ec)
{
System.Windows.Forms.MessageBox.Show(ec.Message);
return null;
}
}
}
}
具體類我要放置在數據庫中的信息是:
namespace WTF.Edit1.Podaci
{
public class Korisnik
{
public virtual string Tip { get; set; }
public virtual string Ime { get; set; }
public virtual string Prezime { get; set; }
public virtual string KorisnickoIme { get; set; }
public virtual string Lozinka { get; set; }
public virtual string PonovljenaLozinka { get; set; }
public virtual string Email { get; set; }
public virtual string Pol { get; set; }
public virtual IList<Recept> Recepti { get; set; }
public virtual IList<Komentar> Komentari { get; set; }
public virtual IList<Ocena> Ocene { get; set; }
public Korisnik()
{
Recepti = new List<Recept>();
Komentari = new List<Komentar>();
Ocene = new List<Ocena>();
}
}
public class User : Korisnik
{
}
public class Admin : Korisnik
{
}
}
和映射是:
namespace WTF.Edit1.Mapiranja
{
class KorisnikMapiranja : ClassMap<Korisnik>
{
public KorisnikMapiranja()
{
Table("KORISNIK");
Id(x => x.KorisnickoIme, "USERNAME");
Map(x => x.Ime, "IME");
Map(x => x.Prezime, "PREZIME");
Map(x => x.Email, "EMAIL");
Map(x => x.Lozinka, "PASSWORD");
Map(x => x.PonovljenaLozinka, "PASSREPEAT");
Map(x => x.Pol, "POL");
Map(x => x.Tip, "TIP");
HasMany(x => x.Recepti).KeyColumn("USERNAME");
HasMany(x => x.Komentari).KeyColumn("USERNAME");
HasMany(x => x.Ocene).KeyColumn("USERNAME");
}
}
class UserMapiranja : SubclassMap<User>
{
public UserMapiranja()
{
Table("USERI");
KeyColumn("USERNAME");
}
}
class AdminMapiranja : SubclassMap<Admin>
{
public AdminMapiranja()
{
Table("ADMIN");
KeyColumn("USERNAME");
}
}
}
有任何想法嗎?我試圖研究並找到答案,但沒有爲我工作。
您可以檢查頂級異常的'InnerException'屬性,並將其添加到你的問題。它通常很詳細,通常會告訴你確切的問題。 –