- 浏览: 94700 次
- 性别:
- 来自: 深圳
-
文章分类
最新评论
@ Hibernate3.0 àJBOSS
@ ORM à「对象/对应关系」(Object/Relational Mapping)
@ Hibernate3.0 依赖底层的JDBC2.0
Hibernate入门 - 包作用详解 (25个jar)
@必须的jar
hibernate3.0.jar: 必须使用的jar包
antlr.jar: Hibernate使用ANTLR来产生查询分析器
EHCache.jar: Hibernate可以使用不同cache缓存工具作为二级缓存。缺省的cache缓存
cglib-asm.jar: Hibernate用它来实现PO字节码的动态生成,非常核心的库,
dom4j.jar: 是一个Java的XML 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:
Xerces是XML解析器,Xalan是格式化器,xml-apis实际上是JAXP。一般App Server都会带上, Hibernate用XML只不过是读取配置文件。
@ 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的配置信息的Configuration用session的操作
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();
@ Criteria的API不完善.
Session中的find()方法被取消了,必須使用Session的createQuery()建立Query實例,並使用list()方法來取代。Session的iterate()被取消了,由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即是如此,可以利用Query或Criteria的setLockMode()方法來設定要鎖定的表或列(Row)及其鎖定模式,可設定的鎖定模式有以下的幾個:
- LockMode.UPGRADE:利用資料庫的for update子句進行鎖定。
- LockMode.UPGRADE_NOWAIT:使用for update nowait子句進行鎖定,在Oracle資料庫中使用
Query query = session.createQuery("from User user");
query.setLockMode("user", LockMode.UPGRADE);
也可以在使用Session的load()或是lock()時指定鎖定模式以進行鎖定。
另外還有三種加鎖模式Hibernate內部自動對資料進行鎖定,與資料庫無關:
- LockMode.WRITE:在insert或update時進行鎖定,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,則驗證失敗,物件的資料不會儲存至資料庫中
您可以在開啟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);
发表评论
-
Hibernate Validator 实例
2008-06-18 11:21 5727在项目的业务属性中,你是不是要经常验证属性的取值范围呢. 想要 ... -
hibernate Annotations 实例
2008-06-18 11:16 2894从 hbm.xml 到 Annotations 任何获得Ma ... -
HibernateUtilSimple
2008-06-17 10:14 899package org.hibernate.auction.p ... -
HibernateUtil
2008-06-17 10:12 3405package org.hibernate.auction.p ... -
Hibernate的缓存机制介绍
2008-06-16 16:51 956缓存是介于应用程序和� ... -
hibernate常用语句
2008-06-16 16:50 1084Session Session lifecycle begin ... -
hibernate 配置
2008-06-16 16:49 1542第 4 章 配置 由于Hibernate是为了 ... -
对象/关系数据库映射基础
2008-06-16 16:47 1581对象和关系数据库之间的映射通常是用一个XML文档( ... -
集合类(Collections)映射
2008-06-16 16:45 993(译者注:在阅读本章的时候,以后整个手册的阅读过程中,我们都会 ... -
Hibernate包作用详解
2008-06-16 16:43 804Hibernate一共包括了23个ja ... -
HibenateMinute(二)
2008-06-16 16:37 1236Criteria: Criteria criteria = s ... -
HibenateMinute(三)
2008-06-16 16:35 927hiberate缓存 一般而言,ORM的数据缓存应包含如下几个 ... -
Hibernate关系映射
2008-06-16 16:34 1029第 8 章 关联关系映射 8.1. 介绍 ... -
Hibernate对象共事
2008-06-16 16:32 1098第 11 章 与对象共� ... -
hibernate查询语言
2008-06-16 16:29 2158第 14 章 批量处理(Batch processing ... -
hibernate提升性能
2008-06-16 16:25 1020第 20 章 提升性能 20.1. 抓 ... -
hibernate工具箱指南
2008-06-16 16:23 1449第 21 章 工具箱指南 可以通过一系列Eclip ... -
hibernate体系结构
2008-06-16 16:20 1765第 3 章 体系结构(A ...
相关推荐
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 资源包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
锁相环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
python大学生就业信息管理系统(django(完整前后端+mysql+说明文档+LW).zip
企业社会信任数据主要涉及到公众对于企业及其行为的信任程度。这种信任度是基于企业的一系列行为和表现来评估的,包括但不限于企业的商业行为、产品质量、服务态度、信息披露透明度、社会责任履行等方面。 本数据使用张维迎数据已匹配整理成面板数据(dta和Excel版本),三个指标:trust1、trust2和trust3。 计算方式:参考《经济研究》张维迎老师的做法,采用中国企业家调查系统的地区信任调查数据,并以此为基础进行加权赋值,得到各省地区信任水平指标。具体做法是:对全国31个省、自治区和直辖市的1500多家企业开展问卷调查,根据调查结果汇总信任度最高的五个地区及其排序信息(问卷中所调查问题为“根据您的经验,您认为哪五个地区的企业比较守信用并排序”),进而对各省所获得的排序数据进行赋值,获得第一位赋值5分、获得第二位赋值4分,依次类推。在此基础上,以各省份在各个位次的得票百分比为权数,对排序赋值进行加权求和,最后取自然对数,得到各省的地区信任指数。 社会信任1(trust1):各得分下加权占比 社会信任2(trust2):最值得信任下的占比 社会信任3(trust3):各得分下加权占
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
该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 图像分割gui可视化代码 ,代码功能有 图像灰度化,显示灰度直方图,阈值分割法,区域分割法,梯度边缘分割法,canny边缘分割,拉普拉斯边缘分割,并且可以进行各个方法的比较 ,matlab;图像分割;GUI可视化;图像灰度化;灰度直方图;阈值分割法;区域分割法;梯度边缘分割法;Canny边缘分割;拉普拉斯边缘分割法;方法比较,MATLAB图像分割GUI:多法比较与可视化
FilesToPdfUtils.java
112让人
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 资源包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
该项目是Kubernetes内核驱动的云原生分布式操作系统KubeSphere的设计源码,涵盖14049个文件,其中Go语言编写文件占比最高,达11875个。此外,还包括HTML、JavaScript、Shell、C、CSS、Python等多种编程语言。KubeSphere旨在构建一个易于集成第三方应用和云原生生态组件的架构,支持多云和跨集群的统一分发与运维管理。
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
模块化多电平变流器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 内容:构建了包含电热气多能协同的微电网模型,考虑了含有碳配额和碳交易的优化运行机制,并在热电联产机组模型中改进加入了碳捕集系统和电转气装置,以降低碳排放。 然后,基于纳什谈判理论建立了多微网电能共享合作运行模型,进而将其分解为微网联盟效益最大化子问题和合作收益分配子问题,选择交替方向乘子法分布式求解。 对于学习ADMM求解,碳捕集,P2G,多微网交互建模十分有用。 ,非对称纳什谈判;多微网电能共享;微网模型;碳配额;碳交易;碳捕集系统;电转气装置;交替方向乘子法;ADMM求解;P2G;多微网交互建模,基于Matlab+Yalmip的碳捕集与多微网电能共享模型研究
双碳目标下综合能源系统低碳运行优化调度策略:结合分时优化机制、碳交易与双层需求响应,运用Matlab+Yalmip+Cplex求解,涉及多种机组与设备的联合优化调度,以系统成本最优为核心目标。,双碳目标下综合能源系统低碳运行优化调度策略:基于Matlab+Yalmip+Cplex的联合调度方法与碳交易机制结合研究,双碳目标下综合能源系统低碳运行优化调度Matlab程序(用Matlab+Yalmip+Cplex) 原创改进 分时优化机制+碳交易+双层需求响应优化+综合能源系统IES联合低碳优化调度:采用四个场景控制变量分析调度优化模) 目标函数:系统运维成本、购能成本、碳交易成本,三部分构成成本最优。 考虑的机组和设备:燃气轮机、余热锅炉、ORC余热回收装置、燃气锅炉、热泵、电制冷机、储电系统、储热系统,并且有考虑到储能爬坡功率。 注:有lunwen参考文献,有数据文档。 ,双碳目标;综合能源系统;低碳运行优化调度;Matlab程序;Yalmip;Cplex;分时优化机制;碳交易;双层需求响应优化;IES联合低碳优化调度;成本最优;机组和设备;储能爬坡功率,双碳目标下的综合能源系统低碳
基于DBSCAN密度聚类的风电-负荷场景生成与削减模型研究:数据预处理与场景提取的优化方法,基于DBSCAN密度聚类的风电与负荷场景生成与削减模型研究,[1]关键词:密度聚类 场景削减 DBSCAN 场景生成与削减; k-mean聚类 [2]参考文档:《氢能支撑的风-燃气耦合低碳微网容量优化配置研究》第3章 [3]主要内容:代码主要做的是一个基于DBSCAN密度聚类的风电-负荷场景生成与削减模型,首先,采集风电、电负荷历史数据。 然后,通过采用 DBSCAN 密度聚类的数据预处理消除异常或小概率电负荷、风电数据。 之后,针对风电波动性与电负荷时序性、周期性特点,将场景提取分为电负荷场景提取和风电场景提取。 不同于传统的Kmeans方法,此方法更加具有创新性,场景模型与提取更具有代表性,代码非常nice ,密度聚类; DBSCAN; 场景生成与削减; k-mean聚类; 风电场景提取; 负荷场景提取; 数据预处理; 历史数据采集; 代表性场景模型。,基于DBSCAN密度聚类的风电-负荷场景生成与削减模型研究
技术选型 【后端】:Java 【框架】:springboot/ssm 【前端】:小程序 【JDK版本】:JDK1.8 【服务器】:tomcat7+ 【数据库】:mysql 5.7+ 压缩包包含项目源码+数据库脚本+万字文档。 项目包含前后台完整源码,都经过本人调试,确保可以正常运行! 具体项目介绍可查看博主文章或私聊获取。 也可提供远程调试、二次开发、项目讲解服务,有意向可私聊。 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!