sessionFactory的创建和四种查询方式
1,关于sessionFactory的创建
5.0版本之前,下面这种方式在5.0及之后,可能会出问题,建议修改为5.0之后的方式
// 实例化Configuration
Configuration configuration = new Configuration();
// 加载hibernate.cfg.xml文件
configuration.configure("/hibernate.cfg.xml");
// 创建SessionFactory
StandardServiceRegistryBuilder standardServiceRegistryBuilder = new StandardServiceRegistryBuilder();
standardServiceRegistryBuilder.applySettings(configuration
.getProperties());
SessionFactory sessionFactory = configuration
.buildSessionFactory(standardServiceRegistryBuilder.build());
5.0版本以及5.0之后
SessionFactory sessionFactory = new Configuration().configure("/hibernate.cfg.xml").buildSessionFactory();
官方建议的方法
StandardServiceRegistry standardRegistry = new StandardServiceRegistryBuilder()
.configure( "hibernate.cfg.xml" )
.build(); Metadata metadata = new MetadataSources( standardRegistry )
.addAnnotatedClass( HiberNew.class )
.getMetadataBuilder()
.applyImplicitNamingStrategy( ImplicitNamingStrategyJpaCompliantImpl.INSTANCE )
.build(); SessionFactory sessionFactory = metadata.getSessionFactoryBuilder().build();
hibernate获取sessionFactory的工具类
public class HibernateUtils {
private static String CONFIG_FILE_LOCATION = "/hibernate.cfg.xml";
private static final ThreadLocal<Session> threadLocal
= new ThreadLocal<Session>();
private static SessionFactory sessionFactory;
private static String configFile = CONFIG_FILE_LOCATION;
/* 静态代码块创建SessionFactory */
static {
try {
sessionFactory = new Configuration().configure(configFile).buildSessionFactory();
} catch (Exception e) {
System.err.println("%%%% Error Creating SessionFactory %%%%");
e.printStackTrace();
}
}
private HibernateUtils() {
}
/**
* 返回ThreadLocal中的session实例
*/
public static Session getSession() throws HibernateException {
Session session = (Session) threadLocal.get();
if (session == null || !session.isOpen()) {
if (sessionFactory == null) {
rebuildSessionFactory();
}
session = (sessionFactory != null) ? sessionFactory.openSession()
: null;
threadLocal.set(session);
}
return session;
}
/**
* 返回Hibernate的SessionFactory
*/
public static void rebuildSessionFactory() {
try {
sessionFactory = new Configuration().configure(configFile).buildSessionFactory();
} catch (Exception e) {
System.err.println("%%%% Error Creating SessionFactory %%%%");
e.printStackTrace();
}
}
/**
* 关闭Session实例并且把ThreadLocal中副本清除
*/
public static void closeSession() throws HibernateException {
Session session = (Session) threadLocal.get();
threadLocal.set(null);
if (session != null) {
session.close();
}
}
/**
* 返回SessionFactory
*/
public static SessionFactory getSessionFactory() {
return sessionFactory;
}
public static void setConfigFile(String configFile) {
HibernateUtils.configFile = configFile;
sessionFactory = null;
}
}
2.hibernate的使用
这里要注意,hibernate不会自动产生数据库,所以你需要自己先建立一个空数据库,编码设置为utf8,hibernate自己建表时会参考数据库的编码格式
1)配置文件hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 配置访问Oracle数据库参数信息 -->
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="connection.url">
jdbc:mysql://127.0.0.1:3306/hibTest?useUnicode=true&characterEncoding=UTF-8
<!-- jdbc:oracle:thin:@localhost:1521:orcl -->
</property>
<property name="connection.username">root</property>
<property name="connection.password">password</property>
<!-- 在控制台显示SQL语句 -->
<property name="show_sql">true</property>
<!--根据需要自动生成、更新数据表 -->
<property name="hbm2ddl.auto">update</property>
<!-- 注册所有ORM映射文件 -->
<mapping resource="com/qst/chapter05/pojos/Student.hbm.xml" />
<!-- <mapping resource="com/qst/chapter05/pojos/User.hbm.xml" /> -->
<mapping class="com.qst.chapter05.pojos.TestAno" />
<mapping class="com.qst.chapter05.pojos.User" /> </session-factory>
</hibernate-configuration>
2)POJO 不建议用xml的方式,用注解更简单易读
package com.qst.chapter05.pojos; import java.io.Serializable; import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="user")
public class User implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
/* 用户ID */
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name = "id", insertable = false, updatable = false)
private Integer id;
/* 用户名 */
@Column(name = "user_name")
private String userName;
/* 密码 */
@Column(name = "user_pwd")
private String userPwd;
/* 权限 */
@Column(name = "role")
private Integer role;
/* 默认构造方法 */
public User() {
}
/* 根据属性创建 构造方法 */
public User(String userName, String userPwd,Integer role) {
this.userName = userName;
this.userPwd=userPwd;
this.role=role;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getUserPwd() {
return userPwd;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
public Integer getRole() {
return role;
}
public void setRole(Integer role) {
this.role = role;
} }
测试代码
session自带的方法
保存
public class UserDemo { public static void main(String[] args) {
// 创建User对象
User user = new User("zhangsan", "123", 1);
SessionFactory sessionFactory = new Configuration().configure("/hibernate.cfg.xml").buildSessionFactory();
// 打开Session
Session session = sessionFactory.openSession();
// 开始一个事务
Transaction trans = session.beginTransaction();
// 持久化操作
session.save(user);
// 提交事务
trans.commit();
// 关闭Session
session.close();
} }
更新
session.update(user);
查询
User user = (User) session.get(User.class, key);
HQL语句
Query query = session.createQuery("from User");
// 执行查询
List<User> list = query.list();
// 遍历输出
for (User u : list) {
System.out.println(u.getId() + "\t" + u.getUserName() + "\t"
+ u.getUserPwd() + "\t" + u.getRole());
}
SQL查询,这个查完了需要手工映射,比较麻烦
Query query = session.createSQLQuery("select * from user");
// 执行查询
List<Object[]> list = query.list();
// 遍历输出
for (Object[] u : list) {
System.out.println(u[0] + "\t" + u[1] + "\t"
+ u[2] + "\t" + u[3]);
}
Criteria查询
Criteria criteria = session.createCriteria(User.class);
// 执行查询
List<User> list = criteria.list();
// 遍历输出
for (User stu : list) {
System.out.println(stu.getId() + "\t" + stu.getUserName() + "\t"+stu.getUserPwd());
}
sessionFactory的创建和四种查询方式的更多相关文章
- Hibernate的四种查询方式(主键查询,HQL查询,Criteria查询,本地sql查询)和修改和添加
Hibernate的添加,修改,查询(三种查询方式)的方法: 案例演示: 1:第一步,导包,老生常谈了都是,省略: 2:第二步,创建数据库和数据表,表结构如下所示: 3:第三步创建实体类User.ja ...
- Spring Data Jpa的四种查询方式
一.调用接口的方式 1.基本介绍 通过调用接口里的方法查询,需要我们自定义的接口继承Spring Data Jpa规定的接口 public interface UserDao extends JpaR ...
- Hibernate第四天——查询方式
Hibernate入门最后一天第四天,我们进行查询方式的更进一步的细化: 先看一下大致的Hibernate的提供的查询的方式: 1.对象导航查询 2.OID查询 3.HQL查询 4.QBC查询 5.本 ...
- Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...
- Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (二) —— SQLite
SQLite是一种转为嵌入式设备设计的轻型数据库,其只有五种数据类型,分别是: NULL: 空值 INTEGER: 整数 REAL: 浮点数 TEXT: 字符串 BLOB: 大数据 在SQLite中, ...
- [Android]Android数据的四种存储方式
存储方式 Android提供以下四种存储方式: SharePreference SQLite File ContentProvider Android系统中数据基本都是私有的,一般存放在“data/d ...
- Hibernate的Api以及三种查询方式
Hibernate Api |-- Configuration 配置管理类对象 config.configure(); 加载主配置文件的方法(hibernate.cfg.xml) ...
- (转)Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...
- [转][Android]Android数据的四种存储方式
android.database.sqlite类 SQLiteQueryBuilder java.lang.Object android.database.sqlite.SQLiteQueryBuil ...
随机推荐
- 九度oj 题目1020:最小长方形
题目描述: 给定一系列2维平面点的坐标(x, y),其中x和y均为整数,要求用一个最小的长方形框将所有点框在内.长方形框的边分别平行于x和y坐标轴,点落在边上也算是被框在内. 输入: 测试输入 ...
- BZOJ 3168 [Heoi2013]钙铁锌硒维生素 ——矩阵乘法 矩阵求逆
考虑向量ai能否换成向量bj 首先ai都是线性无关的,然后可以a线性表出bj c1*a1+c2*a2+...=bj 然后移项,得 c1/ci*a1+...-1/ci*bj+...=ai 所以当ci不为 ...
- HDU 3001 Travelling ——状压DP
[题目分析] 赤裸裸的状压DP. 每个点可以经过两次,问经过所有点的最短路径. 然后写了一发四进制(真是好写) 然后就MLE了. 懒得写hash了. 改成三进制,顺利A掉,时间垫底. [代码] #in ...
- 使用反射获取类中的属性(可用于动态返回PO类的列,当做表格的表头)
//利用反射取类中的属性字段 try { Class clazz = Class.forName("houji.bean.model.TaskModel"); Field[] fi ...
- 玩转css样式选择器----当父元素有多个子元素时选中最后一个
- HDU 4770 Lights Against Dudely 暴力枚举+dfs
又一发吐血ac,,,再次明白了用函数(代码重用)和思路清晰的重要性. 11779687 2014-10-02 20:57:53 Accepted 4770 0MS 496K 2976 B G++ cz ...
- spring data jpa使用原生sql查询
spring data jpa使用原生sql查询 @Repository public interface AjDao extends JpaRepository<Aj,String> { ...
- pyserial安装
参考网址:pyserial.sourceforge.net/pyserial.html#installation Download the archive from http://pypi.pytho ...
- 迈出从3K到1W的重要一步——掌握设计模式
IT职场的小菜经常有这样的疑问: 为什么一个相似的功能,大牛一会儿就搞定,然后悠闲地品着下午茶逛淘宝:而自己加班加点搞到天亮还做不完. 为什么用户提出需求变更后,大牛只需潇洒地敲敲键盘,改改配置:而自 ...
- gdb源码安装过程中的问题:no termcap library found
gdb使用源码安装的时候遇到错误:no termcap library found ./configure --> make --> make install 解决办法,下载termca ...