JavaEE 之 Habernate
1.Habernate
a.定义:Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO(简单java对象,即javabean)与数据库表建立映射关系,是一个全自动的ORM框架
b.ORM:对象关系映射(Object Relation Mapping)
2.使用:
a.在SRC下建hibernate.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>
<property name="connection.url">
jdbc:mysql://localhost:3306/j116
</property>
<property name="connection.username">root</property>
<property name="connection.password">admin</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<mapping resource="com/wode/pojo/User.hbm.xml" />
</session-factory>
</hibernate-configuration>
b.建User的映射配置User.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.wode.pojo.User" table="users">
<id name="userId" column="user_id" type="integer">
<generator class="native"></generator>
</id>
<property name="userName" column="user_name" type="string"></property>
<property name="userPwd" column="user_pwd" type="string"></property>
<property name="userType" column="user_type" type="int"></property>
</class>
</hibernate-mapping>
c.使用
User u=new User();
u.setUserName("test");
u.setUserPwd("test");
u.setUserType(1);
Configuration cfg=new Configuration();
cfg.configure();//加载hibernateConfiguration
ServiceRegistry registry=new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
SessionFactory factory=cfg.buildSessionFactory(registry);
Session session=factory.openSession();
Transaction tx=session.beginTransaction();
session.save(u);
tx.commit();
session.close();
3.增删查改
a.增
session.save(u);
b.删
session.delete(u); //需要设置User的Id
c.查
//方法一:hql
Query query = session.createQuery("from User");
List<User> list=query.list(); //方法二:sql
Query query =session.createSQLQuery("select * from users").addEntity(User.class);
List<User> list=query.list(); //方法三:单个对象
User u=(User) session.load(User.class, 1);//延迟加载
User u=(User) session.get(User.class, 1);
d.改
//方法一
User u = (User) session.get(User.class, 1);
u.setUserPwd("123456");
session.beginTransaction().commit(); //方法二(没set的属性将自动设为空,不建议使用)
User u = new User();
u.setUserId(1);
u.setUserPwd("123456");
session.update(u);
session.beginTransaction().commit();
4.查询拓展
a.分页查询
Query query = session.createQuery("from User");
//当前页
int currentPage = 1;
//一页多少条
int pageSize = 5; query.setFirstResult((currentPage-1)*pageSize);
query.setMaxResults(pageSize); List<User> list = query.list();
for(User u : list){
System.out.println(u.getUserName()+" "+u.getUserPwd());
}
b.聚合函数
Query query=session.createQuery("select count(*) from Course");
c.模糊查询
//Query query = session.createQuery("from User u where u.userName like ?");
//query.setString(0, "%z%");
Query query = session.createQuery("from User u where u.userName like :name");
query.setString("name", "%z%");
List<User> list = query.list();
d.不用session的方式
Query query=session.createQuery("delete Course c where c.courseName =wa ");
int =query.executeUpdate()
5.一对多
a.在Many方xml中配置
<many-to-one name="dept" class="com.wode.entity.Dept" column="deptNo" lazy="false" fetch="join"/>
b.在One方xml中配置
<set name="emps" lazy="false" fetch="join" cascade="all">
<key column="deptNo"></key>
<one-to-many class="com.wode.entity.Emp"/>
</set>
c.级联添加
Dept dept = new Dept();
dept.setDeptNo(40);
dept.setDname("销售部");
dept.setLoc("红瓦寺"); Emp emp = new Emp();
emp.setEmpno(9527);
emp.setEname("若湖");
...
emp.setDept(dept); Emp emp2 = new Emp();
emp2.setEmpno(9528);
emp2.setEname("江瑕");
...
emp2.setDept(dept); Set<Emp> emps = new HashSet<Emp>();
emps.add(emp);
emps.add(emp2);
dept.setEmps(emps); session.save(dept);
session.beginTransaction().commit();
d.级联删除
Dept dept = (Dept) session.get(Dept.class, 40);
session.delete(dept);
session.beginTransaction().commit();
e.通过Dept删除某个Emp
Dept dept = (Dept) session.get(Dept.class, 40);
Set<Emp> emps = dept.getEmps();
Iterator<Emp> it = emps.iterator();
while(it.hasNext()){
if(it.next().getEname().equals("江瑕")){
it.remove();
}
}
session.beginTransaction().commit();
f.查找所有的Dept以及所有Dept里面的Emp
List<Dept> depts = session.createQuery("select distinct(d) from Dept d join fetch d.emps").list();
for(Dept dept : depts){
System.out.println(dept.getDname());
for(Emp emp : dept.getEmps()){
System.out.println(emp.getEname());
}
}
6.多对多
a.配置xml
<set name="courses" table="t_s_fk">
<key column="sId"></key>
<many-to-many class="Course" column="cId"></many-to-many>
</set>
b.添加(近增加相互之间的关系)
Student stu = (Student) session.get(Student.class, 3);
Course course1 = (Course) session.get(Course.class, 1);
Course course2 = (Course) session.get(Course.class, 3); stu.getCourses().add(course1);
stu.getCourses().add(course2); session.beginTransaction().commit();
c.通过科目名称查找选了这门课程的学生
Course course = (Course) session.get(Course.class, 1);
Set<Student> stus = course.getStus();
for(Student stu : stus){
System.out.println(stu.getStuName());
}
7.注解方式
a.将 <mapping resource="com/wode/pojo/Emp.hbm.xml" /> 改为 <mapping class="com.wode.pojo.Emp" />
b.标注方法参考Spring Data JPA
8.二级缓存
a.在src下创建ehcache.xml
b.在hibernate.cfg.xml中配置
<property name="cache.use_second_level_cache">true</property>
<property name="cache.use_query_cache">true</property>
<property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property>
c. 在Bean的映射配置xml中配置
<cache usage="read-only" region="sampleCache1"/>
d.若使用的是注解则加@注解
@Cache(usage = CacheConcurrencyStrategy.READ_ONLY)
9.Habernate在Spring中的使用
a.在web.xml及applicationContext.xml中配置相应配置
b.使用:
@Autowired
@Qualifier("sessionFactory")
private SessionFactory sessionFactory; @Override
public void addUser(User user) {
// TODO Auto-generated method stub
Session session = sessionFactory.getCurrentSession();
session.save(user);
}
JavaEE 之 Habernate的更多相关文章
- [Java面经]干货整理, Java面试题(覆盖Java基础,Java高级,JavaEE,数据库,设计模式等)
如若转载请注明出处: http://www.cnblogs.com/wang-meng/p/5898837.html 谢谢.上一篇发了一个找工作的面经, 找工作不宜, 希望这一篇的内容能够帮助到大 ...
- javaEE设计模式——门面模式
1.本节内容 门面模式的意图介绍 门面模式带来的好处 门面模式的应用场景 实现模式的3中方式:POJO.无状态与有状态回话Bean门面 有状态与无状态回话Bean门面的重要差别 关于门面模式使用的警告 ...
- 【解决方案】cvc-complex-type.2.4.a: Invalid content was found starting with element 'init-param'. One of '{"http://java.sun.com/xml/ns/javaee":run-as, "http://java.sun.com/xml/ns/javaee":security-role-r
[JAVA错误] cvc-complex-type.2.4.a: Invalid content was found starting with element 'init-param'. One o ...
- [JavaEE笔记]Cookie
引言 由于 Http 是一种无状态的协议,服务器单从网络连接上无从知道客户身份. 会话跟踪是 Web 程序中常用的技术,用来跟踪用户的整个会话.常用会话跟踪技术是 Cookie 与 Session. ...
- JavaEE开发基础
1 JavaEE简介 Java平台有三个版本,分别是JavaSE(Java Platform, Standard Edition),JavaEE(Java Platform, Enterprise E ...
- javaEE基础08
javaEE基础08 一.继承 特点:继承父类的属性和方法,单继承(多继承) 特性:方法的复写(重写) 比如:人可以养狗 人------>狗:整体和部分(拥有)关系 关键字:extends 结构 ...
- JavaEE:JavaEE技术组成
Java平台版本: JavaSE:Java Platform Standard Edition,标准版,用来开发桌面应用系统: JavaEE:Java Plateform Enterprise Edi ...
- JavaEE中Web服务器、Web容器、Application服务器区别及联系
在JavaEE 开发Web中,我们经常会听到Web服务器(Web Server).Web容器(Web Container).应用服务器(Application Server),等容易混淆不好理解名词. ...
- Linux服务器oraclejdk与openjdk共存并配置JavaEE开发环境
由于本人学业的需要,需要在linux中搭建JavaEE开发环境,与windows的同学协同开发. JDK 由于fedora默认使用openjdk,移除多多少少会出现点问题,由于很多开源软件默认使用到它 ...
随机推荐
- swift 学习- 27 -- 访问控制
// 访问控制 可以限定其源文件 或模块中的代码对你的代码的访问级别, 这个特性可以让我们隐藏代码的一些实现细节, 并且可以为其他人可以访问和使用的代码提供接口 // 你可以明确地给某个类型 (类, ...
- ios 清除缓存文件
获取缓存文件的大小 由于缓存文件存在沙箱中,我们可以通过NSFileManager API来实现对缓存文件大小的计算. 计算单个文件大小 +(float)fileSizeAtPath:(NSStrin ...
- Java 开源博客 Solo 2.5.0 发布
Java 开源博客 Solo 2.5.0 发布 Solo 是一款一个命令就能搭建好的 Java 开源博客系统,如果你想开个独立博客,请一定不要错过! 2.5.0 版本主要支持了 Markdown/JS ...
- mybatis常见错误总结
1. 现象:mybatis xml文件中查询的返回类型写成list或java.util.List时,执行sql时报 java.lang.UnsupportedOperationException错误. ...
- 封装input 逐渐,且input插件必须带有默认值。
封装input 逐渐,且input插件必须带有默认值. 组件: <template> <div class="input-show"> <span c ...
- swagger2常用注解说明
说明: 1.这里使用的版本:springfox-swagger2(2.4)springfox-swagger-ui (2.4) 2.这里是说明常用注解的含义和基本用法(也就是说已经对swagger进行 ...
- JMeter 提供了六种定时器
JMeter提供了六种定时器,下面让我们一起来学习下JMeter的定时器. 先明确一些概念: 1)定时器是在每个sampler(采样器)之前执行的,而不是之后: 是的,你没有看错,不管这个定时器的位置 ...
- 论文阅读笔记二十七:Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks(CVPR 2016)
论文源址:https://arxiv.org/abs/1506.01497 tensorflow代码:https://github.com/endernewton/tf-faster-rcnn 室友对 ...
- [转] jQuery的deferred对象详解
jQuery的开发速度很快,几乎每半年一个大版本,每两个月一个小版本. 每个版本都会引入一些新功能.今天我想介绍的,就是从jQuery 1.5.0版本开始引入的一个新功能----deferred对象. ...
- 清北合肥day2-day5
day2:215这一天的题目相对比较模板化t1:50看错了数据范围求n个点到给出的点哈夫曼距离的最小值我想到的是一种非常zz的做法我们二分答案,然后判断是否在这个距离内有点但是这样前缀和不是很好维护于 ...