NHibernate数据库配置详解 (nhibernat数据库配置)

NHibernate是一个流行的开源对象关系映射(ORM)框架,它提供了一种简单的方式来操作数据库,可以快速地将对象映射到数据库表中。NHibernate是在Hibernate之上构建的,因此它继承了Hibernate的所有优点,并且在Hibernate的基础上增加了一些新功能和改进。

本文将详细介绍如何配置NHibernate数据库连接和映射以及优化NHibernate应用程序的性能。

一、NHibernate数据库连接

1.1 配置文件

在配置NHibernate数据库连接之前,我们需要在应用程序的根目录下创建一个名为“hibernate.cfg.xml”的XML配置文件。该文件包含了各种配置属性,例如用于连接数据库的用户名、密码、数据库连接字符串等。

通常,NHibernate配置文件应该包含以下属性:

– 驱动程序类名:JDBC驱动程序的类名。

– 数据库连接字符串:指向数据库的URL。

– 用户名:登录数据库时使用的用户名。

– 密码:登录数据库时使用的密码。

– 方言:指示NHibernate如何在特定的数据库上生成SQL语句。

下面是一个示例配置文件:

“`xml

NHibernate.Dialect.MySQLDialect

NHibernate.Driver.MySqlDataDriver

Server=localhost; Database=mydatabase; Uid=myusername; Pwd=mypassword;

“`

1.2 创建SessionFactory

SessionFactory是一个线程安全的对象,它可以创建Session对象。Session是与数据库连接相关的最主要的类之一。在应用程序中使用NHibernate时,通常只需要创建一个SessionFactory实例。

以下是创建SessionFactory的代码示例:

“`csharp

var sessionFactory = new NHibernate.Cfg.Configuration().Configure().BuildSessionFactory();

“`

二、NHibernate映射

2.1 类映射

在使用NHibernate时,我们需要将.NET类映射到数据库表中。这可以通过创建.hbm.xml文件来实现,其中包含了.NET类和数据库表之间的映射规则。

具体步骤如下:

1. 在.NET代码中创建一个类,该类将映射到数据库表。

2. 在应用程序根目录下创建一个名为“mapping”的文件夹,并在该文件夹中创建一个名为“MyClass.hbm.xml”的文件。

3. 在文件中定义.NET类和数据库表之间的映射规则。

下面是一个示例hbm.xml文件:

“`xml

“`

在这个示例文件中,我们定义了一个名为“MyClass”的.NET类,并将其映射到名为“MyTable”的数据库表中。

2.2 查询映射

NHibernate还提供了一种查询映射的方式,可以在查询SQL语句和数据库表之间建立一个映射关系。这可以通过在.hbm.xml文件中定义元素来实现。

以下是一个示例查询映射的代码:

“`xml

<![CDATA[

SELECT Column1, Column2 FROM MyTable WHERE Id = :id

]]>

“`

三、NHibernate性能优化

3.1 预处理语句

NHibernate可以使用PreparedStatement来执行SQL语句,这样可以提高性能,因为PreparedStatement缓存了已经执行过的SQL语句并重复使用。

以下是一些性能优化的代码示例:

“`csharp

var session = sessionFactory.OpenSession();

var query = session.CreateQuery(“SELECT * FROM MyClass WHERE Name=:name”);

query.SetParameter(“name”, “John Smith”);

query.List();

“`

在上面的示例中,NHibernate将执行预处理语句,这样可以加快查询速度。

3.2 使用缓存

NHibernate还提供了各种缓存机制,用于提高性能并减少数据库访问次数。其中最常见的是第二级缓存,它可以为.NET对象提供持久性,以便它们可以被多个Session共享。

以下是使用第二级缓存的代码示例:

“`csharp

var configuration = new Configuration().Configure();

configuration.SetProperty(Environment.UseSecondLevelCache, “true”);

configuration.SetProperty(Environment.CacheProvider, typeof(MyCacheProvider).AssemblyQualifiedName);

var sessionFactory = configuration.BuildSessionFactory();

“`

在这个代码示例中,我们指定了NHibernate使用第二级缓存,并设置了MyCacheProvider作为缓存提供程序。

3.3 批量处理操作

当需要在数据库中插入或更新多个记录时,NHibernate提供批量处理操作,可以将多个SQL语句打包成单个操作,从而提高性能。

以下是批量处理操作的示例代码:

“`csharp

var session = sessionFactory.OpenSession();

var transaction = session.BeginTransaction();

try

{

for (int i = 0; i

{

var myClass = new MyClass()

{

Property1 = “Value1” + i,

Property2 = “Value2” + i

};

session.SaveOrUpdate(myClass);

}

transaction.Commit();

}

catch (Exception)

{

transaction.Rollback();

}

“`

在这个示例中,我们使用了一个循环将多个MyClass对象插入到数据库中。由于我们将多个保存操作打包成了单个操作,因此性能得到了提高。

相关问题拓展阅读:

如何基于Hibernate在Java类中实现,根据数据库表生成持久化类代码和映射文件hbm.xml

这者败首个很简单啊,用首数My Eclipse 里的那个MyEclipse Database Explorer 就可以实现反向枯橘生成了啊

这个就要借助hibernate tools跟伏手xdoclet来完成了;

首先你要在你的java代码里缺弯嫌应用xdoclet标签,例如

Java code

private String name;

/**

* @hibernate.property column = “name” length = “50”

*/

public String getName() {

return this.name;

}

public void setName(String name) {

this.name = name;

}

其中, column = “name” length = “50”

就是xdoclet标签,它需要xdoclet程序来处理,这里就需要用到hibernate tools。

具体做的话一般情况是建一个ant脚本来完成,例如:

XML code

++

||

| R U N N I N G H I B E R N A T E D O C L E T |

||

++

上面的代码是生成hbm跟cfg文件的,下面再介绍如何从java类到数据库:

XML code

++

||

| R U N N I N G D B S C H E M A |

||

++

当然ant工程里的一些初始化需要自己定义,我这里只摘录关键部分,具体的东西请查阅相关文档,hibernate tutorail里就有个例子

没必要用ant脚本,MyEclipse对Hibernate支持得很好。

具体参照以下:

在hibernate中,每个数据表对应的其实是一个实体类,每个实体类有一个对应的hbm.xml配置文件和你匹配,myeclipse中其实有个MyEclipse Database Explorer视图,它提供了myeclipse与数据库直接连接的内置窗口,并且通过此窗口可以生成hibernate的mapping文件。

1.在项目上点击右键选择MyEclipse选项,为应用增加Hibernate特性.

2.在出现的配置窗口中,选中“Add Hibernate 2.1 libraries to project?”,然后设定存放Hibernate库文件的目录为: /WEB-INF/lib 目录,默认会选择创建一个新的Hibernate配置文件hibernate.cfg.xml。

3.点击下一步,进入Hibernate数据基高拆库连接配置界面,在Connection Profile选项中直接选择在MyEclipse Database Explorer中配置的vipdata选项,然后就会自动生成其他的配置,可以选择“Copy JDBC Driver and add to classpath”,这样就会将JDBC驱动拷贝到WEB-INF/lib目录中。:

4.点击下一步,来创建Hibernate的SessionFactory类,这是一个简单的集中管理Hibernate会话的工厂类,填写类的全名称。

5.点击完成,然后MyEclipse就会将Hibernate相关的jar包拷贝到lib目录下,同时会生成Hibernate的配置文件:hibernate.cfg.xml,和SessionFactory类。

现在要利用MyEclipse Database Explorer视图中的工具来生成Hibernate的映射文件。切换到MyEclipse Database Explorer视图,在表vipdata上点击右键,选择Create Hibernate Mapping.

6.配置生成的持久化类和映射文件。

7.点击Browse,选择生成的类和映射文件的包:com.

8.ID Generator算法选项念漏,选择native。(还有很多其他的选项可选,根据应用的需要具体选择,好像hibernate映搏枣射的表必须有主健,否则无法利用hibernate技术)。

9.点击完成,这样会生成持久化类Vipdata和它的父类AbstractVipdata(生成父类,有利于日后应用的扩展,工具会自动生成详细的equals方法和hashCode方法)以及映射文件.hbm.xml。同时会修改Hibernate的配置文件hibernate.cfg.xml,会增加一行.

到此,hibernate mapping文件生成结束。:)

其实,eclipse对struts的支持也是很强大的,按照相似的步骤进行配置。很多的工作量就可以完全交给eclipse了

就是根据db_table 生产 java类和映射文件是不?

简单:

假设你用netbeans或者Eclipse,(都差不多)

1,找到配置好的数据库,

2,打开数据库连接

3,选中需要生成的java文件的表

4,右键 –有生成hbm等字样,点一雀芦下就好咯

都是这陵闷样的,没必要用ant,省力省顷汪带心……

选我哦

可能Hibernate不足以实现你的功能,不过可以用JDBC自己做,因为JDBC提供了各种API用以获取数据库的信息,我想ANT也是用JDBC实现的,就比如,

获取数据库的表的各种字段,类型等芦巧,我想Hibernate似乎做不到这个,而JDBC可以

不知道我历纤这样说你理解否?肢哗仿

node cannot be resolved for the specified context 是什么错误?spring.net + nhibernate配置问题

这种情况我遇到过,有蚂团两种可能

1.类中芹枯声明的服务名称和注入的名称不匹配

2.类中声明服务时,忘记了修饰符闷首橘protected或 public

关于nhibernat数据库配置的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » NHibernate数据库配置详解 (nhibernat数据库配置)