`

HibenateMinute(一)

阅读更多

@ Hibernate3.0 àJBOSS

@ ORM à对象/对应关系」(Object/Relational Mapping

@ Hibernate3.0 依赖底层的JDBC2.0

 

Hibernate - 包作用 (25jar)

@jar

hibernate3.0.jar: 使用的jar

antlr.jar: Hibernate使用ANTLR查询分析

EHCache.jar: Hibernate可以使用不同cache存工具作级缓存。缺省的cache

cglib-asm.jar: Hibernate用它来实现PO节码动态生成,非常核心的

  dom4j.jar: 是一个JavaXML API Hibernate用它来写配置文件。

  odmg.jar:是一个ORM范,Hibernate实现ODMG范,是一个核心的  commons-collections.jar包含了一些Apache开发的集合

  commons-beanutils.jar,包含了一些Bean工具类类。必使用的jar包。

  commons-lang.jar:些数据型工具,是java.lang.*展。必使用的jar

commons-logging.jar:包含了日志功能

@:

  ant.jar: Ant编译工具的jar包,用来编译Hibernate源代的。

  optional.jar Ant的一个助包。

  c3p0.jar C3PO是一个数据库连接池,Hibernate可以配置使用C3PO接池。

  proxool.jar 也是一个接池,同上。

  commons-pool.jar:commons-dbcp.jar:  Tomcat4接池也是DBCP

EJB中使用Hibernate,一定要用App Server接池,否容器管理事不起作用.

  connector.jar: JCA 范, App Server上把Hibernate配置Connector

Jaas.jar: JAAS是用来验证的,已包含在JDK1.4里面了。

jcs.jar 如果你准Hibernate中使用JCS,那包括它,否就不用。

jdbc2_0-stdext.jar: JDBC2.0展包,一般来数据库连接池会用上它。

jta.jar JTA范,当Hibernate使用JTA候需要,

junit.jar: Junit包,当你运行Hibernate测试候需要,否就不用。

xalan.jar:xerces.jar:xml-apis.jar:

XercesXML解析器,Xalan是格式化器,xml-apis实际上是JAXP。一般App Server都会上, HibernateXML只不取配置文件  

 

@ log4j.properties

Hibernate包的etc目录下的log4j.properties复制到Hibernate项目的Classpath,

修改log4j.logger.org.hibernate = error!

@ 实体对象的加载!

 <hibernate-configuration>

    <session-factory> 

 <!-- 对象与数据库表的映射文件 -->

       <mapping resource="onlyfun/caterpillar/User.hbm.xml"/>

    </session-factory>

</hibernate-configuration>

@ 获得负责管理Hibernate的配置信息的Configurationsession操作

Configuration config = new Configuration().configure();

//configure()默认./Hibernate.cfg.xml; 当然也可以指定URL

SessionFactory sessionFactory = config.buildSessionFactory();

Session session = sessionFactory.openSession();

Transaction tx= session.beginTransaction();

session.save(user);// user实体

tx.commit();

session.close();

sessionFactory.close();

@ CriteriaAPI不完善.

Session中的find()方法被取消了,必須使用SessioncreateQuery()建立Query實例,並使用list()方法來取代。Sessioniterate()被取消了,由Query介面上的iterator()來取代,詳請看 Query.list()iterator()

新增 update 語句

Query query = session.createQuery("update User set age=30 where id=1");

query.executeUpdate();

新增 delete 語句

Query query = session.createQuery("delete User where age<20");

query.executeUpdate();

  Query:

  1:query = session.createQuery("from User user where user.name like ?");

    query.setParameter(0, "caterpillar");

   2 :Query query = session.createQuery("select user.name from User as user where user.age > :minAge");
query.setInteger("
minAge", 25);

4. 悲觀鎖定(Pessimistic Locking

   悲觀鎖定通常透過系統或資料庫本身的功能來實現,依賴系統或資料庫本身提供的鎖定機制,Hibernate即是如此,可以利用QueryCriteriasetLockMode()方法來設定要鎖定的表或列(Row)及其鎖定模式,可設定的鎖定模式有以下的幾個:

  • LockMode.UPGRADE:利用資料庫的for update子句進行鎖定。
  • LockMode.UPGRADE_NOWAIT:使用for update nowait子句進行鎖定,在Oracle資料庫中使用

Query query = session.createQuery("from User user");

query.setLockMode("user", LockMode.UPGRADE);

也可以在使用Sessionload()或是lock()時指定鎖定模式以進行鎖定。

另外還有三種加鎖模式Hibernate部自動對資料進行鎖定,與資料庫無關:

  • LockMode.WRITE:在insertupdate時進行鎖定,Hibernate會在save()方法時自動獲得鎖定。
  • LockMode.READ:在讀取記Hibernate會自動獲得鎖定。 
  • LockMode.NONE:沒有鎖定。

如果資料庫不支援所指定的鎖定模式,Hibernate會選擇一個合適的鎖定替換,而不是丟出一個例外

5: Lifecycle 介面、Validatable 介面

    可以在實體物件定義時實作Lifecycle介面,這個介面定義如下:

package org.hibernate.classic;

import java.io.Serializable;

import org.hibernate.CallbackException;

import org.hibernate.Session;

public interface Lifecycle {

    public static final boolean VETO = true;

    public static final boolean NO_VETO = false;

    public boolean onSave(Session s) throws CallbackException;

    public boolean onUpdate(Session s) throws CallbackException;

    public boolean onDelete(Session s) throws CallbackException;

    public void onLoad(Session s, Serializable id);

}

當物件實作Lifecycle介面時,會在save()update()delete()load()等方法執行之前呼叫對應的onSave() onUpdate()onDelete()onLoad(),其中onSave()onUpdate()onDelete()onLoad() 若傳回true或丟出CallbackException,則對應的操作中止。

可以在實體物件定義時實作Validatable介面,其定義如下:

package org.hibernate.classic;

public interface Validatable {

    public void validate() throws ValidationFailure;

}

如果定義時實作了Validatable介面,當物件被持久化之前會呼叫validate()方法,如果丟出ValidationFailure,則驗證失敗,物件的資料不會儲存至資料庫中

Interceptor 介面

    您可以在開Session時載入一個自訂Interceptor,這個Interceptor會在對應的動作發生之前呼叫對應的方法,方法是讓您定義的Interceptor實作Interceptor介面,介面的定義如下:

package org.hibernate;

import java.io.Serializable;

import java.util.Iterator;

import org.hibernate.type.Type;

public interface Interceptor {

    // 載入物件之前執行

    public boolean onLoad(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) throws CallbackException;

    // flush 時,如果發現有Dirty data,則執行此方法

    public boolean onFlushDirty(Object entity, Serializable id, Object[] currentState, Object[] previousState, String[] propertyNames, Type[] types) throws CallbackException;

    // 儲存物件前執行

    public boolean onSave(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) throws CallbackException;

    // 刪除物件前執行

    public void onDelete(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) throws CallbackException;

    // flush 前執行

    public void preFlush(Iterator entities) throws CallbackException;

    // flush 後執行

    public void postFlush(Iterator entities) throws CallbackException;

    // 判斷傳入的物件是否為 transient

    public Boolean isTransient(Object entity);

    // flush 前呼叫這個方法判斷 Dirty data

    // 傳回Dirty data屬性索引或null採預設行為

    public int[] findDirty(Object entity, Serializable id, Object[] currentState, Object[] previousState, String[] propertyNames, Type[] types);

    // 手動建立實體物件,如果傳回 null,則使用預設的建構方法建立實例

    public Object instantiate(String entityName, EntityMode entityMode, Serializable id) throws CallbackException;

    // 傳回實體名稱

    public String getEntityName(Object object) throws CallbackException;

    // 取得實體物件

    public Object getEntity(String entityName, Serializable id) throws CallbackException;

    // beginTransaction() 之後執行

    public void afterTransactionBegin(Transaction tx);

    // 在事務完成前執行

    public void beforeTransactionCompletion(Transaction tx);

    // 在事務完成後執行

    public void afterTransactionCompletion(Transaction tx);}

假設您實作了SomeInterceptor類別:

package onlyfun.caterpillar;

....

public class SomeInterceptor implements Interceptor {

    ....

}


在開Session時,可以如下載入自訂的Interceptor

SomeInterceptor someInterceptor = new SomeInterceptor();

Session session = sessionFactory.openSession(someInterceptor);

分享到:
评论

相关推荐

    【weixin9168】“返家乡”高校暑期社会实践微信小程序设计与开发ssm.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 资源包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    【weixin9098】基于微信小程序的电子购物系统的设计与实现+ssm.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    锁相环Simulink仿真研究:单同步坐标系与多种改良型锁相环的技术分析与实践,基于多种锁相环技术的Simulink仿真研究:单同步坐标系与对称分量法锁相环、双dq锁相环与双二阶广义积分锁相环等的技术

    锁相环Simulink仿真研究:单同步坐标系与多种改良型锁相环的技术分析与实践,基于多种锁相环技术的Simulink仿真研究:单同步坐标系与对称分量法锁相环、双dq锁相环与双二阶广义积分锁相环等的技术探讨与模型实现,锁相环simulink仿真,1:单同步坐标系锁相环(ssrf-pll),2:对称分量法锁相环(ssrfpll上面加个正序分量提取),3:双dq锁相环(ddsrf-pll),4:双二阶广义积分锁相环(sogi-pll),5:sogi-fll锁相环,6:剔除直流分量的sogi锁相环的simulink仿真 可提供仿真数据和自己搭建模型时的参考文献,仿真数据仅供参考 ,关键词: 1. 锁相环;Simulink仿真 2. 单同步坐标系锁相环(SSRF-PLL) 3. 对称分量法锁相环(正序分量提取) 4. 双DQ锁相环(DDSRF-PLL) 5. 双二阶广义积分锁相环(SOGI-PLL) 6. SOGI-FLL锁相环 7. 剔除直流分量的SOGI锁相环 8. 仿真数据 9. 参考文献,基于多种锁相环技术的Simulink仿真研究:从单同步到双二阶广义积分

    hfp1.9版本spec

    hfp1.9版本spec

    python大学生就业信息管理系统(django(完整前后端+mysql+说明文档+LW).zip

    python大学生就业信息管理系统(django(完整前后端+mysql+说明文档+LW).zip

    企业社会信任数据(2004-2023年).dta

    企业社会信任数据主要涉及到公众对于企业及其行为的信任程度。这种信任度是基于企业的一系列行为和表现来评估的,包括但不限于企业的商业行为、产品质量、服务态度、信息披露透明度、社会责任履行等方面。 本数据使用张维迎数据已匹配整理成面板数据(dta和Excel版本),三个指标:trust1、trust2和trust3。 计算方式:参考《经济研究》张维迎老师的做法,采用中国企业家调查系统的地区信任调查数据,并以此为基础进行加权赋值,得到各省地区信任水平指标。具体做法是:对全国31个省、自治区和直辖市的1500多家企业开展问卷调查,根据调查结果汇总信任度最高的五个地区及其排序信息(问卷中所调查问题为“根据您的经验,您认为哪五个地区的企业比较守信用并排序”),进而对各省所获得的排序数据进行赋值,获得第一位赋值5分、获得第二位赋值4分,依次类推。在此基础上,以各省份在各个位次的得票百分比为权数,对排序赋值进行加权求和,最后取自然对数,得到各省的地区信任指数。 社会信任1(trust1):各得分下加权占比 社会信任2(trust2):最值得信任下的占比 社会信任3(trust3):各得分下加权占

    【weixin9097】家具购物小程序+php.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    基于Vue框架的工程管控2.0前端Vue.js TypeScript JavaScript CSS HTML设计源码

    该Vue框架驱动的工程管控2.0前端项目,包含了841个文件,涵盖丰富的组件和资源,其中SVG图形379个,Vue组件190个,TypeScript脚本92个,JavaScript脚本68个,CSS样式49个,JSON配置11个,HBS模板10个,PNG图片9个,SCSS样式8个,OTF字体5个。项目源码以TypeScript和JavaScript为主,辅以CSS和HTML,旨在提供一个全面的前端解决方案。

    Matlab图像分割GUI:灰度化、直方图显示、阈值分割与多种边缘检测方法的可视化比较,Matlab图像分割GUI:灰度化、直方图显示、阈值分割与多种边缘检测方法的可视化比较,matlab 图像分割g

    Matlab图像分割GUI:灰度化、直方图显示、阈值分割与多种边缘检测方法的可视化比较,Matlab图像分割GUI:灰度化、直方图显示、阈值分割与多种边缘检测方法的可视化比较,matlab 图像分割gui可视化代码 ,代码功能有 图像灰度化,显示灰度直方图,阈值分割法,区域分割法,梯度边缘分割法,canny边缘分割,拉普拉斯边缘分割,并且可以进行各个方法的比较 ,matlab;图像分割;GUI可视化;图像灰度化;灰度直方图;阈值分割法;区域分割法;梯度边缘分割法;Canny边缘分割;拉普拉斯边缘分割法;方法比较,MATLAB图像分割GUI:多法比较与可视化

    FilesToPdfUtils.java

    FilesToPdfUtils.java

    112俄而日纠结1225667

    112让人

    【weixin9196】运动健康小程序SpringBoot.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 资源包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    【weixin9230】疫苗预约小程序ssm.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    基于Kubernetes内核的云原生分布式操作系统KubeSphere设计源码

    该项目是Kubernetes内核驱动的云原生分布式操作系统KubeSphere的设计源码,涵盖14049个文件,其中Go语言编写文件占比最高,达11875个。此外,还包括HTML、JavaScript、Shell、C、CSS、Python等多种编程语言。KubeSphere旨在构建一个易于集成第三方应用和云原生生态组件的架构,支持多云和跨集群的统一分发与运维管理。

    【weixin9242】基于微信小程序的外卖点餐系统设计与实现ssm.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

    模块化多电平变流器MMC的VSG控制策略:基于MATLAB-Simulink仿真模型的调频调压效果验证,模块化多电平变流器MMC的VSG控制策略及MATLAB-Simulink仿真研究:三相交流源下的

    模块化多电平变流器MMC的VSG控制策略:基于MATLAB-Simulink仿真模型的调频调压效果验证,模块化多电平变流器MMC的VSG控制策略及MATLAB-Simulink仿真研究:三相交流源下的调频调压效果分析,模块化多电平变流器 MMC 的VSG控制 同步发电机控制 MATLAB–Simulink仿真模型 5电平三相MMC,采用VSG控制。 受端接可编辑三相交流源,直流侧接无穷大电源提供调频能量。 设置频率波动和电压波动的扰动,可以验证VSG控制的调频调压效果 ,VSG控制; MMC模块化多电平变流器; MATLAB-Simulink仿真模型; 5电平三相MMC; 调频调压效果; 频率波动; 电压波动,基于VSG控制的5电平三相MMC模块化仿真模型研究

    基于纳什谈判理论的多微网电能共享协同优化模型:碳配额与交易下的微电网合作运行及收益分配策略分析(Matlab+Yalmip实现),基于纳什谈判理论的微电网电能共享机制优化与效益最大化探讨-引入碳配

    基于纳什谈判理论的多微网电能共享协同优化模型:碳配额与交易下的微电网合作运行及收益分配策略分析(Matlab+Yalmip实现),“基于纳什谈判理论的微电网电能共享机制优化与效益最大化探讨——引入碳配额与交易的碳捕集系统与电转气装置研究”,非对称纳什谈判多微网电能共享 程序语言:matlab+yalmip 内容:构建了包含电热气多能协同的微电网模型,考虑了含有碳配额和碳交易的优化运行机制,并在热电联产机组模型中改进加入了碳捕集系统和电转气装置,以降低碳排放。 然后,基于纳什谈判理论建立了多微网电能共享合作运行模型,进而将其分解为微网联盟效益最大化子问题和合作收益分配子问题,选择交替方向乘子法分布式求解。 对于学习ADMM求解,碳捕集,P2G,多微网交互建模十分有用。 ,非对称纳什谈判;多微网电能共享;微网模型;碳配额;碳交易;碳捕集系统;电转气装置;交替方向乘子法;ADMM求解;P2G;多微网交互建模,基于Matlab+Yalmip的碳捕集与多微网电能共享模型研究

    双碳目标下综合能源系统低碳运行优化调度策略:结合分时优化机制、碳交易与双层需求响应,运用Matlab+Yalmip+Cplex求解,涉及多种机组与设备的联合优化调度,以系统成本最优为核心目标 ,双碳目

    双碳目标下综合能源系统低碳运行优化调度策略:结合分时优化机制、碳交易与双层需求响应,运用Matlab+Yalmip+Cplex求解,涉及多种机组与设备的联合优化调度,以系统成本最优为核心目标。,双碳目标下综合能源系统低碳运行优化调度策略:基于Matlab+Yalmip+Cplex的联合调度方法与碳交易机制结合研究,双碳目标下综合能源系统低碳运行优化调度Matlab程序(用Matlab+Yalmip+Cplex) 原创改进 分时优化机制+碳交易+双层需求响应优化+综合能源系统IES联合低碳优化调度:采用四个场景控制变量分析调度优化模) 目标函数:系统运维成本、购能成本、碳交易成本,三部分构成成本最优。 考虑的机组和设备:燃气轮机、余热锅炉、ORC余热回收装置、燃气锅炉、热泵、电制冷机、储电系统、储热系统,并且有考虑到储能爬坡功率。 注:有lunwen参考文献,有数据文档。 ,双碳目标;综合能源系统;低碳运行优化调度;Matlab程序;Yalmip;Cplex;分时优化机制;碳交易;双层需求响应优化;IES联合低碳优化调度;成本最优;机组和设备;储能爬坡功率,双碳目标下的综合能源系统低碳

    基于DBSCAN密度聚类的风电-负荷场景生成与削减模型研究:数据预处理与场景提取的优化方法,基于DBSCAN密度聚类的风电与负荷场景生成与削减模型研究,1关键词:密度聚类 场景削减 DBSCAN

    基于DBSCAN密度聚类的风电-负荷场景生成与削减模型研究:数据预处理与场景提取的优化方法,基于DBSCAN密度聚类的风电与负荷场景生成与削减模型研究,[1]关键词:密度聚类 场景削减 DBSCAN 场景生成与削减; k-mean聚类 [2]参考文档:《氢能支撑的风-燃气耦合低碳微网容量优化配置研究》第3章 [3]主要内容:代码主要做的是一个基于DBSCAN密度聚类的风电-负荷场景生成与削减模型,首先,采集风电、电负荷历史数据。 然后,通过采用 DBSCAN 密度聚类的数据预处理消除异常或小概率电负荷、风电数据。 之后,针对风电波动性与电负荷时序性、周期性特点,将场景提取分为电负荷场景提取和风电场景提取。 不同于传统的Kmeans方法,此方法更加具有创新性,场景模型与提取更具有代表性,代码非常nice ,密度聚类; DBSCAN; 场景生成与削减; k-mean聚类; 风电场景提取; 负荷场景提取; 数据预处理; 历史数据采集; 代表性场景模型。,基于DBSCAN密度聚类的风电-负荷场景生成与削减模型研究

    【weixin9262】高校校园交友微信小程序springboot.zip

    技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!

Global site tag (gtag.js) - Google Analytics