Hibernate基础:快速入门(3):SessionFactory和Session
来源:互联网 发布:淘宝店铺规划方案 编辑:程序博客网 时间:2024/06/05 02:13
这里也像前面的JDBC的Sample那样,如何设定Hibernate的设定文件,如何从SessionFactory中取出一个session。
hibernate.cfg.xml
创建如下所示的hibernate的设定文件
<?xml version="1.0" encoding="utf-8"?><!DOCTYPE hibernate-configuration SYSTEM "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration> <session-factory> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hbtestdb?useSSL=false</property> <property name="hibernate.connection.username">hbtestuser01</property> <property name="hibernate.connection.password">hbtestuser01</property> <property name="show_sql">true</property> <property name="current_session_context_class">thread</property> </session-factory></hibernate-configuration>
Hibernate properties
Hibernate DB & JNDI properties
Hibernate Dialect
Entity Class:User
我们将会创建一个Entity的User类。Entity类就是用来与数据库的Table进行Mapping的Class。
import javax.persistence.Entity;import javax.persistence.Id;import javax.persistence.Table;import javax.persistence.Column;@Entity@Table (name="hbtableuser")public class User { @Id @Column(name="userid") private int userid; @Column(name="username") private String username; @Column(name="country") private String country; public User(){ System.out.println("Default User construction is called..."); } public User(int userid, String username, String country) { this.userid = userid; this.username = username; this.country = country; } public int getUserid() { return userid; } public void setUserid(int userid) { this.userid = userid; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getCountry() { return country; } public void setCountry(String country) { this.country = country; }}
使用xml文件自然也可以,由于注解可能是今后的标准方向,相关的例子都回使用注解方式。各个字段的get/set方法以及default无参的构造函数也都做成。
创建Demo演示代码
import org.hibernate.Session;import org.hibernate.SessionFactory;public class HbDemo01 { public static void main(String[] args){ try{ SessionFactory sessionFactory = new org.hibernate.cfg.Configuration() .configure("hibernate.cfg.xml") .addAnnotatedClass(User.class) .buildSessionFactory(); Session session = sessionFactory.getCurrentSession(); System.out.println("Successfully got connection from session factory."); sessionFactory.close(); }catch (Exception e){ System.out.println("Exception happened..."); e.printStackTrace(); } }}
执行结果
十二月 12, 2016 9:12:14 下午 org.hibernate.Version logVersionINFO: HHH000412: Hibernate Core {5.2.5.Final}十二月 12, 2016 9:12:14 下午 org.hibernate.cfg.Environment <clinit>INFO: HHH000206: hibernate.properties not found十二月 12, 2016 9:12:14 下午 org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>INFO: HCANN000001: Hibernate Commons Annotations {5.0.1.Final}十二月 12, 2016 9:12:14 下午 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl configureWARN: HHH10001002: Using Hibernate built-in connection pool (not for production use!)十二月 12, 2016 9:12:14 下午 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreatorINFO: HHH10001005: using driver [com.mysql.jdbc.Driver] at URL [jdbc:mysql://localhost:3306/hbtestdb?useSSL=false]十二月 12, 2016 9:12:14 下午 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreatorINFO: HHH10001001: Connection properties: {user=hbtestuser01, password=****}十二月 12, 2016 9:12:14 下午 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreatorINFO: HHH10001003: Autocommit mode: false十二月 12, 2016 9:12:14 下午 org.hibernate.engine.jdbc.connections.internal.PooledConnections <init>INFO: HHH000115: Hibernate connection pool size: 20 (min=1)十二月 12, 2016 9:12:15 下午 org.hibernate.dialect.Dialect <init>INFO: HHH000400: Using dialect: org.hibernate.dialect.MySQLDialect十二月 12, 2016 9:12:15 下午 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl stopINFO: HHH10001008: Cleaning up connection pool [jdbc:mysql://localhost:3306/hbtestdb?useSSL=false]Successfully got connection from session factory.
0 0
- Hibernate基础:快速入门(3):SessionFactory和Session
- Hibernate【3】(session和sessionFactory)
- Hibernate之SessionFactory和Session
- hibernate之SessionFactory和Session
- hibernate中的sessionfactory和session
- hibernate的sessionFactory和session
- Hibernate的SessionFactory和Session
- 关于Hibernate的Session和SessionFactory
- 关于Hibernate的Session和SessionFactory
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- 浅谈hibernate的sessionFactory和session
- JVM类加载机制详解(一)JVM类加载过程
- Linux调用opencv编程(一)
- 深入剖析神经网络的运行机理及实现
- myeclipse乱码问题
- POJ 1019Number Sequence(组合数学)
- Hibernate基础:快速入门(3):SessionFactory和Session
- 利用OpenCV求取图像多轮廓质心,并在输出图像上显示质心坐标
- Long Long 的使用
- MaterialDesign的学习
- MAC查看端口占用情况
- Netty简单应用
- 域名、主机和网站之间的区别
- JVM类加载机制详解(二)类加载器与双亲委派模型
- Ubuntu 安装 JDK 7 / JDK8 的两种方式