Hibernate的Api以及三种查询方式
Hibernate Api
|-- Configuration 配置管理类对象
config.configure(); 加载主配置文件的方法(hibernate.cfg.xml) 默认加载src/hibernate.cfg.xml
config.configure(“cn/config/hibernate.cfg.xml”); 加载指定路径下指定名称的主配置文件
config.buildSessionFactory(); 创建session的工厂对象
|-- SessionFactory session的工厂(或者说代表了这个hibernate.cfg.xml配置文件)
sf.openSession(); 创建一个sesison对象
sf.getCurrentSession(); 创建session或取出session对象
|--Session session对象维护了一个连接(Connection), 代表了与数据库连接的会话。Hibernate最重要的对象: 只用使用hibernate与数据库操作,都用到这个对象
session.beginTransaction(); 开启一个事务; hibernate要求所有的与数据库的操作必须有事务的环境,否则报错!
写一个代码测试,如下:
写一个测试类,先将配置管理对象类和session的工厂类加载进来
private static SessionFactory sf; static{ /* * //1、创建配置管理对象 【Configuration:配置管理类对象】 Configuration config=new Configuration(); //加载配置文件(默认加载src/hibernate.cfg.xml)、 config.configure(); //2、根据加载的配置管理类对象,创建sessionFactory对象(代表了整个hibernate.cdg.xml配置文件) SessionFactory sf=config.buildSessionFactory(); */ sf=new Configuration().configure().buildSessionFactory(); }
(1)保存对象(插入数据)
@Test public void testInsert() { //对象 User user=new User(); user.setName("test"); user.setPassword("666"); //根据session工厂,创建session对象(维护了一个连接Connection,代表了数据库连接的会话) Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); /*************执行操作*********/ session.save(user); //提交事物/关闭 transaction.commit(); session.close(); sf.close(); }
(2)、更新对象
/* * 更新对象 */ @Test public void testUpdate() { //对象 User user=new User(); user.setId(4); user.setName("test5"); user.setPassword("666"); //根据session工厂,创建session对象(维护了一个连接Connection,代表了数据库连接的会话) Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); /*************执行操作*********/ //session.update(user); //主键查询 //User user2=(User) session.get(User.class, 1); //User user2=(User) session.load(User.class, 1); //同上 //没有设置主键,执行保存操作(插入数据);设置了主键,执行更新操作(若主键设置的值不存在也会报错) session.saveOrUpdate(user); //System.out.println(user2); //提交事物/关闭 transaction.commit(); session.close(); sf.close(); }
三种查询方式
(1)、HQL查询:
HQL查询与SQL查询区别:
SQL: (结构化查询语句)查询的是表以及字段; 不区分大小写。
HQL: hibernate query language 即hibernate提供的面向对象的查询语言
查询的是对象以及对象的属性。区分大小写。
如下:
//HQL查询 Hibernate query language @Test public void testHQL() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); //HQL查询,查询全部(注意:查询的是对象以及对象的属性,不是表,区分大小写) Query query=session.createQuery("from User where id=1 or id=2"); List<User> users=query.list(); System.out.println(users); transaction.commit(); session.close(); sf.close(); }
(2)、Criteria查询:
完全面向对象的查询。
如下:
//QBC查询 query by Criteria @Test public void testQBC() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); Criteria criteria=session.createCriteria(User.class); //查询条件 criteria.add(Restrictions.eq("id", 1)); List<User> list=criteria.list(); System.out.println(list); transaction.commit(); session.close(); sf.close(); }
(3)、SQL查询
本地SQL查询:
复杂的查询,就要使用原生态的sql查询,也可以,就是本地sql查询的支持!
(缺点: 不能跨数据库平台!)
//SQL查询 @Test public void testSQL() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); //把每一行记录指定为的喜爱那个类型 SQLQuery sqlQuery=session.createSQLQuery("select * from users").addEntity(User.class); List list=sqlQuery.list(); System.out.println(list); transaction.commit(); session.close(); sf.close(); }
用hibernate来分页查询
//分页查询 @Test public void testPage() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); Query query=session.createQuery("from User"); //设置分页参数 从0开始查询 query.setFirstResult(0); //查询的起始记录 query.setMaxResults(4); //查询的条数 List<User> list=query.list(); System.out.println(list); transaction.commit(); session.close(); sf.close(); }
js:获取指定class兼容性问题、
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>获取指定的class</title> <link rel="stylesheet" href=""> </head> <body> <ul> <li></li> <li class="box"></li> <li class="box"></li> <li></li> <li></li> </ul> </body> <script type="text/javascript"> //虽然主流的浏览器都支持,但ie6 7 8都是不支持的 //var ali=document.getElementsByClassName('box'); var ali=getByClass(document,'box'); for (var i = ali.length - 1; i >= 0; i--) { ali[i].style['background']='green'; } //可以封装一个函数来获取className,使得ie6,7,8都支持 function getByClass (oParent,sClass) { var elems=oParent.getElementsByTagName('*'); var arr=[]; for (var i = elems.length - 1; i >= 0; i--) { if (elems[i].className==sClass) { arr.push(elems[i]); } } return arr; } </script> </html>
Hibernate的Api以及三种查询方式的更多相关文章
- hibernate的三种查询方式
hibernate的三种查询方式 目录 hibernate的三种查询方式 1.HQL查询 1.1.SQL概述 1.2.实体查询 1.3.带where的查询 1.3.属性查询 1.4.实体的更新和删除 ...
- 初学者易上手的SSH-hibernate02 三种查询方式
在上一章中已经搭建好了一个hibernate的环境,那么这一章我们就使用这个环境来进行基本CRUD.在这之前我们先了解一个东西:主键生成策略.就是当向数据库表中插入记录的时候,这个记录的主键该如何生成 ...
- EF提供的三种查询方式
這邊簡單介紹一下,ADO.Net Entity Framework 提供的三種查詢方式, Linq to Entities Query Builder Mothed Entity SQL Langua ...
- django 神奇的双下划线,通过外键的三种查询方式
一,用于跨表操作 只要是object后面字符串都是用双下划线__.其它地方用点. 如:的values中的group_code__name.group_code是一个外键 def list(reques ...
- mybatis学习四 mybatis的三种查询方式
<select id="selAll" resultType="com.caopeng.pojo.Flower"> select * from fl ...
- Hibernate的四种查询方式(主键查询,HQL查询,Criteria查询,本地sql查询)和修改和添加
Hibernate的添加,修改,查询(三种查询方式)的方法: 案例演示: 1:第一步,导包,老生常谈了都是,省略: 2:第二步,创建数据库和数据表,表结构如下所示: 3:第三步创建实体类User.ja ...
- Spring IOC以及三种注入方式
IOC是spring的最基础部分,也是核心模块,Spring的其他组件模块和应用开发都是以它为基础的.IOC把spring的面向接口编程和松耦合的思想体现的淋漓尽致. IOC概念 IOC(Invers ...
- python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)
一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...
- Entity Framework 5.0系列之EF概览-三种编程方式
概述 在开发面向数据的软件时我们常常为了解决业务问题实体.关系和逻辑构建模型而费尽心机,ORM的产生为我们提供了一种优雅的解决方案.ADO.NET Entity Framework是.NET开发中一种 ...
随机推荐
- Oracle中B-TREE索引的深入理解(转载)
索引概述 索引与表一样,也属于段(segment)的一种.里面存放了用户的数据,跟表一样需要占用磁盘空间.只不过,在索引里的数据存放形式与表里的数据存放形式非常的不一样.在理解索引时,可以想象一本书, ...
- (转)MVC语法-基础
好久没有关注微软的开发了,今天看到了MVC3,顺便学习学习,我觉得Razor是个不错的做法,比使用<%%>简单多了,而且好看.首先“_”开头的cshtml文档将不能在服务器上访问,和asp ...
- 20145232 韩文浩 《Java程序设计》第5周学习总结
教材学习内容总结 处理异常 教材中使用一个简单的程序,用户连续输入整数最后输入0结束后显示输入数的平均值. 但有时,用户会没有按常规出牌输入不正确的信息,例如"30"输成" ...
- Java理论学时第三节。课后作业。
如果一个类中既有初始化块,又有构造方法,同时还设定了字段的初始值,谁说了算? 运行结果. 根据我的总结,它们三个的优先级是:构造方法 > 字段初始值 > 初始化块. 当多个类之间有继承关系 ...
- linux grep进阶
1.搜寻特定字符串 搜寻特定字符串很简单吧?假设我们要从刚刚的文件当中取得 the 这个特定字符串,最简单的方式就是这样: 那如果想要『反向选择』呢?也就是说,当该行没有 'the' 这个字符串时才显 ...
- POJ1064--Cable master(Binary Search)
Description Inhabitants of the Wonderland have decided to hold a regional programming contest. The J ...
- hdu 3030
这道题主要就是问你,长度为n的序列,有多少种上升的子序列 当前点的情况种数等于前面所有小于它的点的种数相加 + 1 1就是只有这一个点的时候的序列 那就是要多次查询前面比它小的点的种数的和 那么就是区 ...
- Mysql 基本的增删改查
创建数据库 create database 库名; 删除数据库 drop database 库名; 进入数据库 use 库名; 查看所有的表 show tables; 创建表 字段名 数据类型 ...
- C# winform ListBox实现滚动条自动滚动至底部
效果如图: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data ...
- .net图表之ECharts随笔03-热力地图
基于01和02 要得到如图所示的热力地图(我从NuGet上下载的包没有heatmap.js文件,没法直接搞热力图,只好暂时先搞着地图.后面尽量搞一下),一般要设置四个参数——title.tooltip ...