我正在尝试使用流畅的nhibernate映射来学习Nhibernate,并且我创建了一个小型测试应用程序。以下是代码:
UserClass的:
public class User
{
public string UserName { get; set; }
public string Password { get; set; }
public string Role { get; set; }
public string Email { get; set; }
public DateTime JoinDate { get; set; }
}
用户地图类:
public class UserMapping: ClassMap<User>
{
public UserMapping()
{
WithTable("UserT");
Not.LazyLoad();
Id(u => u.UserName);
Map(u => u.Password);
Map(u => u.Role);
Map(u => u.Email);
Map(u => u.JoinDate);
}
}
DAL用户类:
public class DALUser
{
public User GetUserByUserName(string userName)
{
ISessionFactory sessionFactory = Fluently.Configure()
.Database(MsSqlConfiguration.MsSql2005.ConnectionString(c => c.Server("ServerName").Database("DBName").TrustedConnection()))
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<UserMapping>()).BuildSessionFactory();
ISession session = sessionFactory.OpenSession();
return session.Get<User>(userName);
}
}
Nunit测试班:
[TestFixture]
public class UserTest
{
[Test]
public void CanGetUserByUserName()
{
DALUser user1 = new DALUser();
Assert.AreEqual("testUser", user1.GetUserByUserName("testUser").UserName);
}
}
当我尝试运行测试类时,我收到以下错误:对象引用未设置为对象的实例。 我在GetUserByUserName方法中放置了一个断点,并注意到它返回一个null用户。但我无法弄清楚为什么会这样。任何人都可以帮助我吗?
答案 0 :(得分:0)
看一下你的数据库配置是否正确? 您确定数据库服务器是“ServerName”吗? 你有现有的数据库“DBName”