- 浏览: 582371 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
liugang_ok:
zhao_rock 写道看到这篇文章时已经是2015年11月2 ...
毕业三年之际写给可能迷茫的你我 -
ning2-eye:
...
2015年总结和2016年计划 -
sxdtzhaoxinguo:
我竟然看完了,很受启发!
2015年总结和2016年计划 -
hottymg:
...
2015年总结和2016年计划 -
hangzhoujava:
伪命题很多,比如有许多的上市公司还不如未上市公司,大家心里还是 ...
2015年总结和2016年计划
一、 Hibernate访问数据库时加载的过程
对于大多数使用Hibernate的朋友来说,通常使用一下方式来获得Configuration实例: Configuration configure = new Configuration().configure();
在Hibernate中,Configuration是hibernate的入口。在实例化一个Configuration的时候,Hibernate会自动在环境变量(classpath)里面查找Hibernate配置文件hibernate.properties。如果该文件存在,则将该文件的内容加载到一个Properties的实例GLOBAL_PROPERTIES里面,如果不存在,将打印信息 hibernate.properties not found;
接下来Hibernate将所有系统环境变量(System.getProperties())也添加到GLOBAL_PROPERTIES里面。如果配置文件hibernate.properties存在,系统还会进一步验证这个文件配置的有效性,对于一些已经不支持的配置参数,系统将打印出警告信息。
默认状态下configure()方法会自动在环境变量(classpath)下面寻找Hibernate配置文件hibernate.cfg.xml,如果该文件不存在,系统会打印如下信息并抛出HibernateException异常: hibernate.cfg.xml not found;如果该文件存在,configure()方法会首先访问<session-factory>,并获取该元素name的属性,如果name的属性非空,将用这个配置的值来覆盖hibernate.properties的hibernate.session_factory_name的配置的值,从这里我们可以看出,hibernate.cfg.xml里面的配置信息可以覆盖hibernate.properties的配置信息。
接下来configure()方法访问<session-factory>的子元素,首先将使用所有的<property>元素配置的信息来覆盖hibernate.properties里面对应的配置信息。
然后configure()会依次访问以下几个元素的内容
<mapping>
<jcs-class-cache>
<jcs-collection-cache>
<collection-cache>
其中<mapping>是必不可少的,必须通过配置<mapping>,configure()才能访问到我们定义的java对象和关系数据库表的映射文件(hbm.xml),例如:
<mapping resource="Cat.hbm.xml"/>
这样configure()方法利用各种资源就创建了一个Configuration实例。对于整个项目来说,如果用一个本地线程来存放这个Configuration实例,那么整个项目只需要实例化一次Configuration对象(注:Configuration实例很花费时间),也就提高了项目的效率。
二、 Hibernate访问多个数据库的配置
根据以上所述,configure()方法默认是通过访问hibernate.cfg.xml的<mapping>元素来加载我们提供的.hbm.xml文件。我们也可以直接指定hbm.xml文件,例如addClass()方法可以直接通过指定class来加载对应的映射文件,hibernate会将提供的class的全名(包括package)自动转化为文件路径,还可以用addFile方法直接指定映射文件。例如:Configuration configurate = new Configuration().addClass(“Book.class”);
Configuration configurate = new Configuration().addURL(Configuration.class.getResource ("/Book.hbm.xml"));
Configuration config = new Configuration().addFile("/Cat.hbm.xml");
这样,如果用xml配置来配置多个数据库的话,那就写多个配置文件。这里假设对应两个数据库(一个是MySQL,一个是SQLServer),我们可以把其xml文件定义为“mysql.cfg.xml”和“sqlserver.cfg.xml”。则用Configuration类获取SessionFactory的代码如下:
SessionFactory mysqlFactory = new Configuration().configure("/mysql.cfg.xml").buildSessionFactory();
SessionFactory sqlserverFactory = new Configuration().configure("sqlserver.cfg.xml ").buildSessionFactory();
同时连接两个数据库实例:
问题:连接mssql中的vedio 和bbs数据库
解决方案:
1.vedio.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=vedio;
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->
<!-- 持久化类所对应的映射文件 -->
<mapping resource="vedio/Managers.hbm.xml" />
</session-factory>
</hibernate-configuration>
2. bbs.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=bbs;
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->
<!-- 持久化类所对应的映射文件 -->
<mapping resource="bbs/Board.hbm.xml" />
<mapping resource="bbs/BBSUser.hbm.xml" />
<mapping resource="bbs/BBSManager.hbm.xml" />
<mapping resource="bbs/Image.hbm.xml" />
<mapping resource="bbs/Upfile.hbm.xml" />
<mapping resource="bbs/Post.hbm.xml" />
<mapping resource="bbs/BestPost.hbm.xml" />
<mapping resource="bbs/User.hbm.xml" />
<mapping resource="bbs/Groups.hbm.xml" />
<mapping resource="bbs/Help.hbm.xml" />
<mapping resource="bbs/Note.hbm.xml" />
<mapping resource="vedio/Managers.hbm.xml" />
</session-factory>
</hibernate-configuration>
3.VedioHibernateUTL.java
package vedio;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class HibernateUtil {
public static final SessionFactory sessionFactory;
static {
try{
sessionFactory=new Configuration().configure("/vedio.cfg.xml").buildSessionFactory();
}catch(Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static final ThreadLocal<Session> session =new ThreadLocal<Session>();
//create session
public static Session currentSession() throws HibernateException {
Session s= session.get();
if(s==null||!s.isOpen()) {
s=sessionFactory.openSession();
session.set(s);
}
return s;
}
//close session
public static void closeSession() throws HibernateException {
Session s=session.get();
session.set(null);
if(s!=null) {
s.close();
}
}
}
4.BbsHibernateUTL.java
package bbs;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class HibernateUtil {
public static final SessionFactory sessionFactory;
static {
try{
sessionFactory=new Configuration().configure("/bbs.cfg.xml").buildSessionFactory();
}catch(Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static final ThreadLocal<Session> session =new ThreadLocal<Session>();
//create session
public static Session currentSession() throws HibernateException {
Session s= session.get();
if(s==null||!s.isOpen()) {
s=sessionFactory.openSession();
session.set(s);
}
return s;
}
//close session
public static void closeSession() throws HibernateException {
Session s=session.get();
session.set(null);
if(s!=null) {
s.close();
}
}
}
然后写相应的 表名.hbm.xml文件
总结一下:一人数据源对应一个.cfg.xml文件,一个HibernateUTL.java,对应多个 表名.hbm.xml
如果你用spring,多数据库就更简单了,像这段代码可以完成所有配置:
<beans>
<bean id="mysqlDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:mysql://localhost:3306/test</value>
</property>
<property name="driverClassName">
<value>org.gjt.mm.mysql.Driver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>
<bean id="mysqlFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="mysqlDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>
<bean id="sqlserverDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:odbc:test</value>
</property>
<property name="driverClassName">
<value>sun.jdbc.odbc.JdbcOdbcDriver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>
<bean id="sqlserverFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="sqlserverDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>
.......
</beans>
本文转自:http://blog.csdn.net/zhiyi2010/article/details/7644612
对于大多数使用Hibernate的朋友来说,通常使用一下方式来获得Configuration实例: Configuration configure = new Configuration().configure();
在Hibernate中,Configuration是hibernate的入口。在实例化一个Configuration的时候,Hibernate会自动在环境变量(classpath)里面查找Hibernate配置文件hibernate.properties。如果该文件存在,则将该文件的内容加载到一个Properties的实例GLOBAL_PROPERTIES里面,如果不存在,将打印信息 hibernate.properties not found;
接下来Hibernate将所有系统环境变量(System.getProperties())也添加到GLOBAL_PROPERTIES里面。如果配置文件hibernate.properties存在,系统还会进一步验证这个文件配置的有效性,对于一些已经不支持的配置参数,系统将打印出警告信息。
默认状态下configure()方法会自动在环境变量(classpath)下面寻找Hibernate配置文件hibernate.cfg.xml,如果该文件不存在,系统会打印如下信息并抛出HibernateException异常: hibernate.cfg.xml not found;如果该文件存在,configure()方法会首先访问<session-factory>,并获取该元素name的属性,如果name的属性非空,将用这个配置的值来覆盖hibernate.properties的hibernate.session_factory_name的配置的值,从这里我们可以看出,hibernate.cfg.xml里面的配置信息可以覆盖hibernate.properties的配置信息。
接下来configure()方法访问<session-factory>的子元素,首先将使用所有的<property>元素配置的信息来覆盖hibernate.properties里面对应的配置信息。
然后configure()会依次访问以下几个元素的内容
<mapping>
<jcs-class-cache>
<jcs-collection-cache>
<collection-cache>
其中<mapping>是必不可少的,必须通过配置<mapping>,configure()才能访问到我们定义的java对象和关系数据库表的映射文件(hbm.xml),例如:
<mapping resource="Cat.hbm.xml"/>
这样configure()方法利用各种资源就创建了一个Configuration实例。对于整个项目来说,如果用一个本地线程来存放这个Configuration实例,那么整个项目只需要实例化一次Configuration对象(注:Configuration实例很花费时间),也就提高了项目的效率。
二、 Hibernate访问多个数据库的配置
根据以上所述,configure()方法默认是通过访问hibernate.cfg.xml的<mapping>元素来加载我们提供的.hbm.xml文件。我们也可以直接指定hbm.xml文件,例如addClass()方法可以直接通过指定class来加载对应的映射文件,hibernate会将提供的class的全名(包括package)自动转化为文件路径,还可以用addFile方法直接指定映射文件。例如:Configuration configurate = new Configuration().addClass(“Book.class”);
Configuration configurate = new Configuration().addURL(Configuration.class.getResource ("/Book.hbm.xml"));
Configuration config = new Configuration().addFile("/Cat.hbm.xml");
这样,如果用xml配置来配置多个数据库的话,那就写多个配置文件。这里假设对应两个数据库(一个是MySQL,一个是SQLServer),我们可以把其xml文件定义为“mysql.cfg.xml”和“sqlserver.cfg.xml”。则用Configuration类获取SessionFactory的代码如下:
SessionFactory mysqlFactory = new Configuration().configure("/mysql.cfg.xml").buildSessionFactory();
SessionFactory sqlserverFactory = new Configuration().configure("sqlserver.cfg.xml ").buildSessionFactory();
同时连接两个数据库实例:
问题:连接mssql中的vedio 和bbs数据库
解决方案:
1.vedio.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=vedio;
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->
<!-- 持久化类所对应的映射文件 -->
<mapping resource="vedio/Managers.hbm.xml" />
</session-factory>
</hibernate-configuration>
2. bbs.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="bbs">
<!-- 指定连接数据库的用户名 -->
<property name="connection.username">sa</property>
<!-- 指定连接数据库的URL -->
<property name="connection.url">
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=bbs;
</property>
<!-- 指定数据库使用的SQL方言 -->
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<!-- 指定连接数据库的口令 -->
<property name="connection.password">sa</property>
<!-- 指定连接数据库的驱动程序 -->
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- true表示程序运行时,在控制台显示SQL语句,false表示不显示SQL语句 -->
<property name="show_sql">true</property>
<!-- <property name="connection.pool_size">50</property> -->
<!-- 持久化类所对应的映射文件 -->
<mapping resource="bbs/Board.hbm.xml" />
<mapping resource="bbs/BBSUser.hbm.xml" />
<mapping resource="bbs/BBSManager.hbm.xml" />
<mapping resource="bbs/Image.hbm.xml" />
<mapping resource="bbs/Upfile.hbm.xml" />
<mapping resource="bbs/Post.hbm.xml" />
<mapping resource="bbs/BestPost.hbm.xml" />
<mapping resource="bbs/User.hbm.xml" />
<mapping resource="bbs/Groups.hbm.xml" />
<mapping resource="bbs/Help.hbm.xml" />
<mapping resource="bbs/Note.hbm.xml" />
<mapping resource="vedio/Managers.hbm.xml" />
</session-factory>
</hibernate-configuration>
3.VedioHibernateUTL.java
package vedio;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class HibernateUtil {
public static final SessionFactory sessionFactory;
static {
try{
sessionFactory=new Configuration().configure("/vedio.cfg.xml").buildSessionFactory();
}catch(Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static final ThreadLocal<Session> session =new ThreadLocal<Session>();
//create session
public static Session currentSession() throws HibernateException {
Session s= session.get();
if(s==null||!s.isOpen()) {
s=sessionFactory.openSession();
session.set(s);
}
return s;
}
//close session
public static void closeSession() throws HibernateException {
Session s=session.get();
session.set(null);
if(s!=null) {
s.close();
}
}
}
4.BbsHibernateUTL.java
package bbs;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class HibernateUtil {
public static final SessionFactory sessionFactory;
static {
try{
sessionFactory=new Configuration().configure("/bbs.cfg.xml").buildSessionFactory();
}catch(Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static final ThreadLocal<Session> session =new ThreadLocal<Session>();
//create session
public static Session currentSession() throws HibernateException {
Session s= session.get();
if(s==null||!s.isOpen()) {
s=sessionFactory.openSession();
session.set(s);
}
return s;
}
//close session
public static void closeSession() throws HibernateException {
Session s=session.get();
session.set(null);
if(s!=null) {
s.close();
}
}
}
然后写相应的 表名.hbm.xml文件
总结一下:一人数据源对应一个.cfg.xml文件,一个HibernateUTL.java,对应多个 表名.hbm.xml
如果你用spring,多数据库就更简单了,像这段代码可以完成所有配置:
<beans>
<bean id="mysqlDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:mysql://localhost:3306/test</value>
</property>
<property name="driverClassName">
<value>org.gjt.mm.mysql.Driver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>
<bean id="mysqlFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="mysqlDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>
<bean id="sqlserverDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="url">
<value>jdbc:odbc:test</value>
</property>
<property name="driverClassName">
<value>sun.jdbc.odbc.JdbcOdbcDriver</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123</value>
</property>
</bean>
<bean id="sqlserverFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="sqlserverDS"/>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>test.hbm.xml</value>
</list>
</property>
</bean>
.......
</beans>
本文转自:http://blog.csdn.net/zhiyi2010/article/details/7644612
发表评论
-
Windows下64位Apache服务器的安装
2014-07-14 14:06 831首先需要说明的是,Apaceh服务器没有官方的64位版本,只有 ... -
Eclipse反编译jar包查看class文件
2014-03-29 11:54 3291很方便,直接用F3或者ctrl点击查看。 Eclipse反 ... -
OpenCms initialization: Unable to initialize the user driver
2014-01-04 11:41 4202在Eclipse中部署工程,报错误: org.opencms. ... -
Java compiler level does not match the version of the installed Java project fac
2013-11-26 16:36 876出错: Java compiler level does no ... -
读取配置文件中数据
2013-06-17 22:35 1006import java.io.IOException; im ... -
WebService的实现
2013-04-23 15:14 1260一:首先创建个WEB工程,然后: http://ws.Apac ... -
java.lang.OutOfMemoryError: PermGen space及其解决方法
2013-03-14 10:53 769PermGen space的全称是Perman ... -
Source not found for $$FastClassByCGLIB$$7782d62a.invoke(int, Object, Object[])
2012-09-29 10:33 17305最近在用sun.net.ftp.FtpClient下载时总是报 ... -
FtpClient和FTPClient下载的使用
2012-09-28 17:35 36499最近接收一个遗留项目,用的是flex和java,后台用的是my ... -
org.apache.jasper.JasperException: java.lang.ClassNotFoundException
2012-09-06 10:41 21083最近在部署一个J2EE工程时,报如下异常: org.apach ... -
POI和JXL中日期无法显示问题
2012-04-09 22:53 1476在用POI和JXL进行日期处理时,日期格式为“2012/04/ ... -
POI Import Export Excel
2012-03-12 23:12 1949所以我们字段field与单元格cellRef映射信息可以是这样 ... -
Flex+Java+BlazeDS多文件上传
2012-03-12 23:13 2634Flex文件上传功能,后台服务器管理用Java,通信工具Bla ... -
MyEclipse添加lobmok
2011-12-25 16:47 2532方法一: 首先在官网下载lobmok.jar,然后拷贝到项 ... -
JSP传值乱码解决方案
2011-11-30 20:01 25649关于jsp乱码问题的解决 ... -
EL表达式详解
2011-11-05 17:14 542EL表达式 1、EL简介 1)语法结构 ... -
java字符串日期数字格式化处理大全
2011-09-05 15:37 1552在C中可以使用类似printf(“%d %8.2f\\n ... -
MyEclipse7.5序列号破解代码
2011-07-21 16:43 1330运行下面代码,然后控制台提示:please input reg ... -
Hibernate的几种查询方式-HQL,QBC,QBE,离线查询,复合查询,分页查询
2011-07-12 10:31 1846HQL查询方式 这一种我最常用,也是最喜欢用的,因为它写起来灵 ... -
java两个时间相差多少天时分秒
2011-06-24 13:13 5975[size=medium;]package[/size] be ...
相关推荐
hibernate同时配置多个数据库连接 可以同时连接不同IP的不同数据库
项目中我们经常会遇到多数据源的问题,尤其是数据同步或定时任务等项目更是如此。多数据源让人最头痛的,不是配置多个数据源,而是如何能灵活动态的切换数据源。 此项目就是为了解决这个问题。
ssh2连接多个数据库 struts2 hibernate spring 配置连接多个mysql数据库
该配置文件连接的是两个数据库结构相同的数据源,其他比如数据库结构不原理也可行。本人在遇到此问题时上网搜了很多答案结果都不怎么如意,有的太深奥不过思想很好,有的又太不给力,后来自己慢慢研究配置成功后想与...
<br>StaticHbmQuery shq = new StaticHbmQuery(\"hibernate.cfg.xml\"); <br>...... <br>//shq.clear(); //java.util.ArrayList arr = shq.hbmQuery([HQL]); //shq.hbmUpdate([Object]); //shq....
SpringMVC+Hibernate+Spring框架搭建的同一项目调用多个数据库。
学了几天,配置连接数据库实现登录功能的一个小demo,还有很多地方比较模糊,添加包也是全添,很多细节的问题都在研究中
16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...
Spring+Hibernate实现用户登录程序,可执行,里面配置文件是正确的,在mysql中见一个wangwei数据库,再建个user表就可执行
Springboot整合Hibernate thymeleaf,添删改查,分页查询等,单元测试,亲测百分之百可运行,网上好多功能不全,甚至无法运行,这个是我自己亲自跑的,绝对没有问题
但是这种方式有一些不足的是当应用服务器配置了多个应用,而这些应用使用同一个数据库,这会导致不必要的资源浪费,也是同一个应用服务器中存在针对同一个数据库的多个连接池。 也是说我们希望每个应用服务器只有...
16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...
21.1 多个事务并发运行时的并发问题 21.1.1 第一类丢失更新 21.1.2 脏读 21.1.3 虚读 21.1.4 不可重复读 21.1.5 第二类丢失更新 21.2 数据库系统的锁的基本原理 21.2.1 锁的多粒度性及自动锁升级 ...
16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...
16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...
hibernate一对多双向自连接关联映射 15 hibernate多对多关联映射(单向User---->Role) 19 hibernate多对多关联映射(双向User<---->Role) 20 Hibernate的继承关系 21 每棵继承树映射成一张表(hibernate_extends_1) 22 ...
(假若您希望使用其它用户名如root,您需要修改hibernate的数据库配置中的连接参数——位于hibernate.cfg.xml中,以及创建数据库表时的连接参数——位于build.xml中。) 7, 确认ant安装正确. ant可以在此下载: ...
如果应用同时访问多个DB,怎需要为每个数据库创建一个单独的SessionFactory实例。 (3)Session:也被称为持久化管理器,对象级数据库操作。 特点: 1)不是线程安全的,因此在设计软件架构时,应该避免多个线程共享...
16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 ...