我不想要hibernate自动去生成主键,也不想在配置文件里面使用sequnce,我要自己得到oracle的sequnce,怎样获取,已经试过用sql语句,但是执行报错,给个代码
解决方案 »
- sitemesh装饰页面不成功
- 请问如何在struts中获取SessionFactory?
- java.lang.NoClassDefFoundError: org/springframework/core/SmartClassLoader 如何解决
- 请问这种技术怎么实现???(顶者有分)
- 怎么通过程序关闭和启动服务?
- 求助:奇怪的插入语句?(急,急)
- 新手,请各位指点一下
- 简单问题,可能是配置出问题,大家帮忙看一看!!高分送!
- 关于<jsp:include>的问题
- 如何设置tomcat 根目录 及虚拟 目录(含class存放路径)
- hibernate 获取 存储过程结果集
- 实在没办法了,请求远程控制
select seq_name.nextVal from dual
select seq_name.nextVal as myID from dual
select jsf.seq_name.nextVal as myID from dual;
jsf为用户名
的schema,或为sequence建当前连接到数据库的用户同义词
public int getId(final String seqname){
Number n=(Number)this.getHibernateTemplate().execute(new HibernateCallback(){ public Object doInHibernate(Session session) throws SQLException, HibernateException {
SQLQuery query = session.createSQLQuery(
"select "+seqname+ ".nextval SEQID from dual ");
query.addScalar( "SEQID ", new org.hibernate.type.IntegerType());
List children = query.list();
return (Number) children.iterator().next();
}
}
);
return n.intValue();
}
public List exeSql(String sql){
return sessionFactory.getCurrentSession().createSQLQuery(sql).addScalar("SEQID").list(); }这两种方法都是报空指针
包名是:org.hibernate.Hibernate;
public int getId(final String seqname) {
Integer n = (Integer) this.getHibernateTemplate().execute(new HibernateCallback() {
public Object doInHibernate(Session session) throws SQLException, HibernateException {
SQLQuery query = session.createSQLQuery("select " + seqname + ".nextval SEQID from dual ");
//query.addScalar("SEQID ", new org.hibernate.type.IntegerType());
List children = query.list();
if(children.isEmpty()){
return null;
}
else{
String s = children.get(0).toString();
return Integer.parseInt(s);
}
}
});
return n;
}