您的位置:首页 > 编程语言 > Java开发

java---j2ee---hibernate执行原生Sql语句的方法

2007-04-21 16:20 597 查看
本人水平浅劣,不足之处,批评就是了....

======================================modify time:2008-5-5

很久没关注,今天发现旧文发布的方法是调用jdbc时的,不属于hibernate,现已更改如下:

hibernate3的HQL 是面向对象的语法,已经支持 update ,delete from语句,但

目前还不支持insert into语句.

做项目有时候的确需要写原生的sql来方便web开发.

下面是在hibernate Dao类里

1) 调用jdbc的执行方法,最后可以在action里调用它...

比如:

public void InsertData(String MytblName,String Mytitle,String Mycode,String Mycoments){
log.debug("insert into dataitems ---drs");
//使用了原生sql语句
try{
//将传入的类名处理成表名 例如:CTable----〉C_Table
MytblName = "C_"+MytblName.substring(1,MytblName.length());
//插入表 的 sql
String Insert_SQL ="INSERT INTO "+MytblName+
" (C_Title,C_Code,C_Comments)"+
" VALUES ('"+Mytitle+"','"+Mycode+"','"+Mycoments+"')" ;
//获得当前session的数据库连接
Connection CurConn = getSession().connection();
//System.out.println(Insert_SQL);
//生成一个Statement对象
PreparedStatement ps = CurConn.prepareStatement(Insert_SQL);

//执行查询
ps.execute();
//关闭该对象
ps.close();
getSession().flush();

log.debug("insert into dataitems successful");
}
catch (SQLException Re ){ // 异常
log.error("insert into dataitems failed", Re);
Re.printStackTrace();
}

}

2) 用Hibernate本身支持的执行原生SQL:

public List excuteMySQL(String strTableName,String fieldName, Object value) {
log.debug("这里是日志");
try {
String queryString = "select top 1 "+strTableName+"_GUID,"+fieldName+" from "+strTableName+" as model where model."
+ fieldName + "= ?";
Query queryObject = getSession().createSQLQuery(queryString);

//注意是 createSQLQuery 不是createQuery

//后者是执行HQL
queryObject.setParameter(0, value);

return queryObject.list();

} catch (RuntimeException re) {
log.error("execute failed", re);
throw re;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: