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开发中一种 ...
随机推荐
- 为什么要用GCD-Swift2.x
为什么要用GCD-Swift2.x 当今世界,多核已然普及.但是APP却不见得很好的跟上了这个趋势.APP 想要利用好多核就必须可以保证任务能有效的分配.并行执行可以让APP同时执行很多 的任务.这个 ...
- Forward团队-爬虫豆瓣top250项目-成员简介与分工
马壮:擅长html,css,分工:分析网站源码 邢云淇:掌握python,java 分工:爬虫部分代码编写 张良:熟练掌握数据库 分工:数据库部分代码编写 年光宇:掌握c#,python 分工:代码整 ...
- _技巧_SublimeText_打开文件乱码解决
macOS属于Unix分支,默认使用UTF-8编码,当从Window 或者其他Linux 或 Unix系统 拷贝文件过来,由于Window系统使用GBK或者GB2312中文编码,所以会出现乱码现象. ...
- POJ3181--Dollar Dayz(动态规划)
Farmer John goes to Dollar Days at The Cow Store and discovers an unlimited number of tools on sale. ...
- Hadoop读写流程
写流程 读流程 HDFS写数据流程 HDFS读数据流程 网络拓扑-节点距离计算 节点距离:两个节点到达最近的共同祖先的距离总和
- C#操作数据表中XML格式的数据
以前还真没有见过数据表中存储XML格式的数据,刚开始听说的时候,还以为是数据表中有XML的字段类型, 再了解,其实也就是字符串类型的,只不过字符串的格式是XML格式的.确实孤陋寡闻!汗... (可添加 ...
- CentOS 7修改yum源为阿里源
1.备份本地源 1 # mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo_bak 2.获取阿里yum源配置 ...
- solr 下载 有dist目录的(6需要8)
http://archive.apache.org/dist/lucene/solr/ solr6 需要java8
- python packaging
python packaging 一.困惑 作为一个 Python 初学者,我在包管理上感到相当疑惑(嗯,是困惑).主要表现在下面几个方面: 这几个包管理工具有什么不同? * distutils * ...
- Spring Integration Zip不安全解压(CVE-2018-1261)漏洞复现
不敢说分析,还是太菜了,多学习. 文章来源: 猎户安全实验室 存在漏洞的源码下载地址:https://github.com/spring-projects/spring-integration-ext ...