NHibernate是一个流行的开源对象关系映射(ORM)框架,它提供了一种简单的方式来操作数据库,可以快速地将对象映射到数据库表中。NHibernate是在Hibernate之上构建的,因此它继承了Hibernate的所有优点,并且在Hibernate的基础上增加了一些新功能和改进。
坚守“ 做人真诚 · 做事靠谱 · 口碑至上 · 高效敬业 ”的价值观,专业网站建设服务10余年为成都iso认证小微创业公司专业提供企业网站建设营销网站建设商城网站建设手机网站建设小程序网站建设网站改版,从内容策划、视觉设计、底层架构、网页布局、功能开发迭代于一体的高端网站建设服务。
本文将详细介绍如何配置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
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对象插入到数据库中。由于我们将多个保存操作打包成了单个操作,因此性能得到了提高。
相关问题拓展阅读:
这者败首个很简单啊,用首数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.xxx
8.ID Generator算法选项念漏,选择native。(还有很多其他的选项可选,根据应用的需要具体选择,好像hibernate映搏枣射的表必须有主健,否则无法利用hibernate技术)。
9.点击完成,这样会生成持久化类Vipdata和它的父类AbstractVipdata(生成父类,有利于日后应用的扩展,工具会自动生成详细的equals方法和hashCode方法)以及映射文件xxx.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可以
不知道我历纤这样说你理解否?肢哗仿
这种情况我遇到过,有蚂团两种可能
1.类中芹枯声明的服务名称和注入的名称不匹配
2.类中声明服务时,忘记了修饰符闷首橘protected或 public
关于nhibernat数据库配置的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
创新互联服务器托管拥有成都T3+级标准机房资源,具备完善的安防设施、三线及BGP网络接入带宽达10T,机柜接入千兆交换机,能够有效保证服务器托管业务安全、可靠、稳定、高效运行;创新互联专注于成都服务器托管租用十余年,得到成都等地区行业客户的一致认可。
当前题目:NHibernate数据库配置详解(nhibernat数据库配置)
链接分享:http://www.shufengxianlan.com/qtweb/news4/219604.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联