fluent nhibernate 初体验

时间:2022-01-08 01:36:15

离开.net框架两年时间,发展的很快呀。原先自我感觉良好到以为只差一个MVP的考核什么的,现在觉得真的差好远了。

呵呵,废话就不多说了。这次花了两天时间才拿下fluent nhibernate的first project。不过,还没有吃透。先记录一下理解了的部分吧。

第一个任务,将数据库改为oracle而非官网上提供的sqllite。工程中需要导入的dll有:

fluent nhibernate 初体验

同时有个灰常重要的事情,就是要将Oracle.DataAccess设定为复制本地:

fluent nhibernate 初体验

否则就会出现找不到驱动的错误提示。

接下来,是跟着官网的例子,设计一下数据表。在java里面hibernate可以帮忙建表的,我不能说nhibernate不可以,因为可能是我不知道怎么弄。

再有就是配置fluentNhibernate连oracle啦。

  先在web.config里面找到connectionStrings节点,并配置相关的连接串。

<connectionStrings>
        <add connectionString="Data Source=rain;User Id=zyu;Password=zyu;" name="rain"/>
    </connectionStrings>

  需要离题补充说明的是,在net35框架中configuration是被否决的,而推荐使用的ConfigurationManager在新建工程中又木有提供,需要俺们手动添加System.Configuration引用(.net也有不靠谱的地儿)。

  接着就是实例化ISessionFactory啦。

private static ISessionFactory CreateSessionFactory()
{
String conn = ConfigurationManager.ConnectionStrings["rain"].ConnectionString;//不多说了,大家都知道为啥这么干。
FluentConfiguration conf = Fluently.Configure().Database(OracleConfiguration.Oracle10.ShowSql().ConnectionString(c => c.Is(conn))).Mappings(
x => x.FluentMappings.AddFromAssembly(Assembly.GetExecutingAssembly()));
return conf.BuildSessionFactory();
}

  另外需要特别记录的是在实现oracle版本的first project时,与官网例子不同地方是:

  

public class EmployeeMap:ClassMap<Employee>
    {
        public EmployeeMap()
        {
            Table("Employee");//所有的Map类,都需要声明对应的表名称,否则人家会给你加上双引号,让你在saveorupdate的时候,找不到对应的表。
            Id(x => x.Id).Not.Nullable().GeneratedBy.Native(
                builder => builder.AddParam("sequence", "seq_emplyee")); ;//可以使用自己分别定义的序列对象,但是好像都要自己先在plsql中新建。
            Map(x => x.LastName);
            Map(x => x.FirstName);
            References(x => x.Store);
        }
    }//其他的类得代码就不特别列出了。

先记录这么多吧。