- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章持久层ORM框架Hibernate框架的使用及搭建方式由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
hibernate的概念: hibernate是一个ormapping框架(ORM框架,全自动ORM框架) hibernate是一个数据库的操作框架即持久层框架 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库(SQL语句由Hibernate根据对象自动生成)。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用..
提示:以下是本篇文章正文内容,下面案例可供参考 。
。
1、Hibernate的代码是比较简单的。 2、Hibernate是面向对象的操作。 3、Hibernate的数据库移动植性很强。 4、Hibernate的缓存是世界级的.
。
1、不能干预sql语句的生成所以如果一个项目中,如果对sql语句的优化要求比较高,那么不适合用hibernate 2、如果一张表中有千万级别的数据量,也不适合用hibernate(因为缓存机制,它会将大量数据放入缓存) 3、hibernate适合用中小型企业开发软件 4、hibernate不适合处理复杂SQL.
。
项目目录 。
1、第一步导包 。
2、第二步编写Hibernate的配置文件 。
我用的是Mysql数据库,你要是用别的把数据源驱动信息改一下即可.
<?xml version='1.0' encoding='utf-8'?><!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration> <!--创建数据源--> <session-factory> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://127.0.0.1:3306/MySql</property> <property name="connection.username">root</property> <property name="connection.password">root</property> <!-- SQL 方言 --> <property name="dialect">org.hibernate.dialect.OracleDialect</property> <!-- 是否显示SQL --> <property name="show_sql">true</property> <!-- 实现格式化的sql --> <property name="format_sql">true</property> <!-- 是否自动生成对象 create 表示每次都重新建立所需对象 update表示如果有就直接使用,如果修改则更新,如果没有则创建 <property name="hbm2ddl.auto">update</property> --> <!--配置hibernate映射文件 --> <!--配置映射文件--> <mapping resource="com/zrrd/mapper/Dept.hbm.xml"></mapping> </session-factory></hibernate-configuration>
关于方言可以参考下面的图片,根据项目需求配置即可.
3、第三步:编写持久化类(pojo类) 。
package com.zrrd.vo;public class Dept { private Integer deptno; private String dname; private String loc; public Integer getDeptno() { return deptno; } public void setDeptno(Integer deptno) { this.deptno = deptno; } public String getDname() { return dname; } public void setDname(String dname) { this.dname = dname; } public String getLoc() { return loc; } public void setLoc(String loc) { this.loc = loc; } //直接转换,看着方便 @Override public String toString() { return "Dept{" + "deptno=" + deptno + ", dname='" + dname + '\'' + ", loc='" + loc + '\'' + '}'; } public Dept() { super(); } public Dept(Integer deptno, String dname, String loc) { this.deptno = deptno; this.dname = dname; this.loc = loc; }}
4、第四步:编写Hibernate映射文件(*.hbm.xml) 。
该文件完成 持久化类和数据库中指定表的映射。说白了就是说明持久化类对应数据库中的哪张表,类中的每个属性都对应数据库中的那些字段.
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- package="com.javashidai.hibernate001.domain" 指明持久化类所在的包 --><hibernate-mapping package="com.zrrd.vo"> <!-- name="Dept" 表示类名 table="dept" 对应的表名 --> <class name="Dept" table="dept" > <!-- 指明主键对应的属性和字段 name="deptno" 表示持久化类中的deptno对应主键字段 column="deptno"表示是主键字段 --> <id name="deptno" column="deptno"> <!-- 主键生成策略 :序列 --> <generator class="sequence"> <!-- 指明所需的序列名 --> <param name="sequence">SEQ_DEPT</param> </generator> </id> <!-- property指明非主键列 name="dname"表示持久化类中的属性名 length="14"指明数据库中对应字段接收的长度 column="dname" 指明对应数据库中的什么字段 type="string" 对应的数据类型 --> <property name="dname" length="14" column="dname" type="string"/> <property name="loc" length="13" column="loc" type="string"/> </class> </hibernate-mapping>
5、第五步:编写测试类完成对数据库的操作 。
package com.zrrd.text;import com.zrrd.vo.Dept;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;public class Text { public static void main(String[] args){ //读取Hibernate.cfg.xml配置文件 Configuration configuration=new Configuration(); configuration.configure("hibernate.cfg.xml"); //创建sessionfactory工程 SessionFactory sessionFactory=configuration.buildSessionFactory(); //创建Session对象 Session session=sessionFactory.openSession(); //创建实体对象(与数据库中表对应的vo对象为实体对象,进而操作数据库(由Hibernate自动创建SQL语句) Dept dept=session.get(Dept.class,1); System.out.println(dept); session.close(); sessionFactory.close(); }}
执行结果图 。
数据库存的数据 。
。
Hibernate的核心接口一共有6个,分别为:Session、SessionFactory、 Transaction、Query、Criteria和Configuration。这6个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制.
1.Session 。
Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session.
2.SessionFactory 。
SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory.
3.Transaction 。
Transaction 接口是一个可选的API,可以选择不使用这个接口,取而代之的是Hibernate 的设计者自己写的底层事务处理代码。 Transaction 接口是对实际事务实现的一个抽象,这些实现包括JDBC的事务、JTA 中的UserTransaction、甚至可以是CORBA 事务。之所以这样设计是能让开发者能够使用一个统一事务的操作界面,使得自己的项目可以在不同的环境和容器之间方便地移植.
4.Query 。
Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作.
5.Criteria 。
Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。值得注意的是Criteria接口也是轻量级的,它不能在Session之外使用.
6.Configuration 。
Configuration 接口的作用是对Hibernate 进行配置,以及对它进行启动。在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。虽然Configuration 接口在整个Hibernate 项目中只扮演着一个很小的角色,但它是启动hibernate 时所遇到的第一个对象.
。
当然我们在实际开发的项目当中肯定不会CRUD的时候都去写测试类里面的代码,这样会导致项目代码量巨大而且可移植性太差,所以我们要封装一下写一个工具类,用的时候直接调用即可.
public class HibernateUtil { //一个Hibernate容器中只需要一个SessionFactory private static SessionFactory sessionFactory; //利用静态代码框创建SessionFactory对象 static { //创建Configuration对象 Configuration conf = new Configuration(); //加载Hibernate配置文件 conf.configure();//默认加载src下的hibernate.cfg.xml //创建SessionFactory对象 sessionFactory = conf.buildSessionFactory(); } //得到Session对象 public static Session getSession() { return sessionFactory.openSession(); }}
。
我都已经写好啦相关执行的方法,你只要改改返回的类型就可以啦,就像Jpa框架那样,直接在你的项目中使用就可以啦。不用太感谢我,为人民服务! 。
1.根据主键查询对象 。
public Dept selectOne(int deptno) { Dept dept= null; //得到session对象 Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //根据主键得到对应的信息 dept = (Dept) session.get(Dept.class, deptno); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } return dept; }
2.查询全部的信息 。
public static List<Dept> queryDept() { List<Dept> deptList = null; //声明session Session session = null; try { //创建Session对象 session= HibernateUtil.getSession(); //声明HQL :其中Dept为实体类 String hql="from Dept ";//from后写的是类名 //得到Query对象 Query query = session.createQuery(hql); //执行查询 deptList = query.list(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } return deptList; }
3.条件查询 。
public List<Dept> queryDeptByLoc(String loc) { List<Dept> deptList = null; //声明session Session session = null; try { //创建Session对象 session= HibernateUtil.getSession(); //声明HQL :其中Dept为实体类 String hql="from com.zrrd.vo.Dept where loc=:loc ";//:loc表示是参数 //得到query对象 Query query = session.createQuery(hql); //给参数赋值 query.setString("loc", loc);//给指定参数赋值 //查询返回List<Dept> deptList = query.list(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } return deptList; }
4.根据主键删除 。
public void deleteDept(int deptno) { //声明Session对象 Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //开启事务保护 Transaction ta = session.beginTransaction(); //根据id得到对应的值 Dept deleteObj = (Dept) session.get(Dept.class, deptno); //删除该对应 session.delete(deleteObj); //提交事务 ta.commit(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } }
5.根据指定条件删除 。
/** * 利用Hql进行删除 * 根据部门编号进行删除 */ public int deleteDeptByLoc(String loc) { int result =0; //声明Session对象 Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //开启事务保护 Transaction ta = session.beginTransaction(); //编写删除使用的HQL 这里的:loc表示参数名 String hql="delete com.zrrd.vo.Dept where loc=:loc"; //得到Query对象 Query query =session.createQuery(hql); //给参数赋值 query.setString("loc", loc); //执行DML语句 result = query.executeUpdate(); //提交事务 ta.commit(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } return result; }
6.修改单个对象 。
public static void updateDept(Dept dept) { //声明Session对象 Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //开启事务保护 Transaction ta = session.beginTransaction(); //根据持久化对象进行修改 session.update(dept); //提交事务 ta.commit(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } }
7.根据条件进行修改(HQL) 。
public static int updateDeptLoc(String oldLoc,String newLoc) {int result =0; //声明Session对象 Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //开启事务保护 Transaction ta = session.beginTransaction(); //编写删除使用的HQL 这里的:loc表示参数名 String hql="update Dept set loc=:newLoc where loc=:oldLoc"; //得到Query对象 Query query =session.createQuery(hql); //给参数赋值 query.setString("newLoc", newLoc); query.setString("oldLoc", oldLoc); //执行DML语句 result = query.executeUpdate(); //提交事务 ta.commit(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } return result; }
8.将对象存入数据库 。
public static void saveDept(Dept dept) { Session session = null; try { //得到Session对象 session = HibernateUtil.getSession(); //得到事务对象 Transaction ta = session.beginTransaction(); //将持久化对象存入 数据库 session.save(dept); //提交事务 ta.commit(); } catch(Exception e) { e.printStackTrace(); } finally { if(session != null) { session.close(); } } }
。
1、increment:表示hibernate调用所连接的数据库的加一机制为该字段生成信息(即生成主键) 2、identity:表示由所连接的数据本身调用自加一机制为该字段生成信息(即生成主键) Increment 和identity的区别在于前者是由hibernate调用生成机制,后者是数据库本身调用生成机制(即您在建表的时候就声明该字段是自动加一的)。但是以上两种主键生成机制在连接Oracle时都不适用。因为Oracle没有自动加一机制。如果Oracle要用自动加一机制就必须依靠。 3、sequence:表示该字段由数据的序列生成,如果不想指定特定的序列则在Oracle中该序列名字必须叫HIBERNATE_SEQUENCE 用于默认选择.
4、uuid:根据UUID算法生成生成32位字符类型的主键信息.
5、guid:利用数据库提供的sys_guid 函数生成主键。但是要注意不是所有数据库都有sys_guid函数的。所以首选还是uuid 。
6、native:根据具体连接的数据库从identity, sequence或者hilo选择一种来生成主键。适用的数据库根据选择的生成方式确定。(这个情况数据库是可以跨越的,因为它能自动选择生成方案),在Oracle中就必须有名字叫HIBERNATE_SEQUENCE的序列 assigned: 交给应用自己给主键赋值。要注意的是赋值必须在调用save()方法之前完成。适用的数据库根据选择的生成方式确定.
。
在Hibernate中可以使用纯java类型和Hibernate指定类型。在Hibernate框架的内部可以自动对Java类型或者Hibernate类型完成对表的对应。建议在开发中使用java类型,效率比较快 。
。
以上文章只是其中的一部分只是教你如何实现框架实现CRUD的操作,最重要的是后续我要写的知识点:反向创建Hibernate工程、对象(DO对象)的三种状态、一对多关系(在主对象设计从对象集合属性)、多对多、懒加载(延迟加载)、抓取策略、Hibernate的一级缓存(Session缓存)、Hibernate的二级缓存、HQL、Query.list和query.iterator等等,这些才是重中之重,任重而道远.
到此这篇关于持久层ORM框架Hibernate框架的使用及搭建方式的文章就介绍到这了,更多相关ORM框架Hibernate框架使用内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/zhx__/article/details/121062223 。
最后此篇关于持久层ORM框架Hibernate框架的使用及搭建方式的文章就讲到这里了,如果你想了解更多关于持久层ORM框架Hibernate框架的使用及搭建方式的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
为了构建 CentOS 6.5 OSM 切片服务器,我正在寻找一些文档和/或教程。 我试过this one正如我在我的 previous post 中所说的那样但它适用于 Ubuntu 14.04,而
我正在寻找可用于集成任何源代码控制管理系统的通用 git 桥(如 git-svn、git-p4、git-tfs)模板。 如果没有这样的模板,至少有一些关于如何在 git 端集成基本操作的说明(对于其他
1、前言 redis在我们企业级开发中是很常见的,但是单个redis不能保证我们的稳定使用,所以我们要建立一个集群。 redis有两种高可用的方案: High availabilit
简介 前提条件: 确保本机已经安装 VS Code。 确保本机已安装 SSH client, 并且确保远程主机已安装 SSH server。 VSCode 已经安装了插件 C/
为什么要用ELK ELK实际上是三个工具,Elastricsearch + Logstash + Kibana,通过ELK,用来收集日志还有进行日志分析,最后通过可视化UI进行展示。一开始业务量比
在日常办公当中,经常会需要一个共享文件夹来存放一些大家共享的资料,为了保证文件数据的安全,最佳的方式是公司内部服务器搭建FTP服务器,然后分配多个用户给相应的人员。今天给大家分享FileZilla搭
最近由于业务需要,开始进行 Flutter 的研究,由于 Flutter 的环境搭建在官网上有些细节不是很清楚,笔者重新整理输出 1. 配置镜像 由于在国内访问 Flutter
目录 1. 安装go软件包 2. 配置系统变量 3. 安装git 4. 设置go代理 5. 下载gin框架 6. 创建项目 7.
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任
上篇文章给大家介绍了使用docker compose安装FastDfs文件服务器的实例详解 今天给大家介绍如何使用 docker compose 搭建 fastDFS文件服务器,内容详情如下所示:
目录 1.创建Maven 2.Maven目录和porm.xml配置 3.配置Tomcat服务器 1.创建Maven
laravel 官方提供 homestead 和 valet 作为本地开发环境,homestead 是一个官方预封装的 vagrant box,也就是一个虚拟机,但是跟 docker 比,它占用体积
这个tutorial显示了 Razor Pages 在 Asp.Net Core 2 中的实现。但是,当我运行 CLI 命令时: dotnet aspnet-codegenerator razorp
我创建了一个单独的类库项目来存储数据库上下文和模型类。在同一解决方案中,我创建了一个 ASP.NET MVC 项目并引用了类库项目,并在项目的 Web.config 文件中包含了数据库上下文的连接字符
关于代码托管,公司是基于Gitlab自建的,它功能全而强大,但是也比较重,我个人偏向于开源、小巧、轻便、实用,所以就排除了Github,在Gogs和Gitea中选者。Gogs在Github有38
目录 1、高可用简介 1.1 高可用整体架构 1.2 基于 QJM 的共享存储系统的数据同步机制分析 1.3 NameNode 主
Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,它已经在该站点运行超过两年半了。Igor 将源代码以类BSD许可证的形式发布。 在高并发连接的情况
对于我们的 ASP.NET Core 项目,我们使用包管理器控制台中的 Scaffold-DbContext 搭建现有数据库。 每次我们做脚手架时,上下文类与所有实体一起生成,它包含调用 option
我正在使用 .net 核心 2.0。我已经安装了以下 nuget 包:1: Microsoft.AspNetCore.All2: Microsoft.EntityFrameworkCore.Tools
我正在使用 NetBeans 及其 RAD 开发功能开发 JEE6 JSF 应用程序。我想使用脚手架来节省更新 Controller 和模型 View 的时间。 OneToMany 关联在 View
我是一名优秀的程序员,十分优秀!