在使用Hibernate3中,发现执回收表格(MySql表空间)时总是报错,具体如下:
我们回收一个表空间(删除表中所有数据,并回收空间),但Hibernate3中总是报错。这点上觉得Hibernate还真不如IbatiS稳定,这种常用的SQL方法居然都支持的不好。
代码如下:
try {
tx = session.beginTransaction();
session.createQuery("truncate UserVo").executeUpdate();
tx.commit();
} catch (Exception e) {
tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
错误堆栈信息:
java.lang.IllegalArgumentException: node to traverse cannot be null!
at org.hibernate.hql.ast.util.NodeTraverser.traverseDepthFirst(NodeTraverser.java:63)
at org.hibernate.hql.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:280)
at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:182)
at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:136)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:101)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:80)
at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:124)
at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:156)
at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:135)
at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1770)
at com.zakisoft.workspace.initcompt.hib.dao.MyHibernateDao.truncateUser(MyHibernateDao.java:193)
at com.zakisoft.workspace.initcompt.hib.frame.TurncateUserPanel$1$1.run(TurncateUserPanel.java:49)
不过Hibernate还是有自己的解决方案,就是直接执行SQL。代码也很简单,就是利用session.createSQLQuery代替session.createQuery,完整方法如下:
try {
tx = session.beginTransaction();
session.createSQLQuery("truncate table user2").executeUpdate();
tx.commit();
} catch (Exception e) {
tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
这里顺便说一下为什么使用truncate而不用delete
truncate会删除表中所有的数据,包括序列,同时回收表空间。当再插入数据时,序列号是1.
delete仅仅是删除数据,不删除序列,不回收空间。当再插入数据时,序列号是最后的序列号+1。
分享到:
相关推荐
smarty truncate中文乱码解决
sql中 truncate 和 delete 有什么区别
注意这边文章针对的是PRM在 数据字典模式下的Truncate恢复选项不可用时使用,数据字典模式下的Truncate恢复选项是最简单、易用的一种模式,具体使用见《使用PRM恢复Oracle数据库中误truncate截断的表数据》...
本文导读:删除表中的数据的方法有delete,truncate, 其中TRUNCATE TABLE用于删除表中的所有行,而不记录单个行删除操作。TRUNCATE TABLE 与没有 WHERE 子句的 DELETE 语句类似;但是,TRUNCATE TABLE 速度更快,使用...
SQL语句中----删除表数据drop、truncate和delete的用法,对你爱不完
NULL 博文链接:https://steve-111.iteye.com/blog/750326
truncate误操作恢复方法集合truncate误操作恢复方法集合truncate误操作恢复方法集合
TRUNCATE与 DELETE区别,比较两个的不同的特点
因自己前段时间因truncate一张表无法找回,且数据超过60W,平常的企业软件超过1W收费,故整理此内容,希望和我遇到同样问题的新手有帮助
Oracle_授权审计表Truncate权限
实际线上的场景比较复杂,当时涉及了truncate, delete 两个操作,经确认丢数据差不多7万多行,等停下来时,差不多又有共计1万多行数据写入。 这里为了简单说明,只拿弄一个简单的业务场景举例。 测试环境: Percona-...
作为初学者,有时容易混淆truncate,delete,drop之间的根本区别,所有今日小记一下。。。
truncate,delete,drop的异同点
Laravel开发-crawl-truncate 当twitter或facebook crawl bot访问时截断页面源
Oracle中Truncate表的恢复方法.pdf
Oracle_审计表_sys.aud$_授权给用户Truncate权限
truncate,delete以及drop区别汇总,需要可以自己下载看看,个人觉得蛮好的!
Truncate 不会逐个清除用户数据块上的数据,而仅仅重置数据字典和元数据块上的元数据(如存储断头和扩展段图)。 也就是说,此时,基本数据表并未破坏,而是被系统回收,等待被重新分配—因此,要恢复被truncate的...
实现在oracle使用truncate吴删数据的恢复
以前从网上找到的一个smarty模板的中文截取函数cn_truncate,原来的实现方法有几个bug,我对它基本上重写了一遍。...最重要的是解决了中英文混合时候的截取计算长度的问题。而且解决了html 转义字符的长度计算问题。