您的位置:首页 > 数据库

hibernate执行原生Sql语句的方法(转)

2010-03-04 11:02 681 查看
http://www.thecloud.cn/study/program/java/597.html

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

目前还不支持insert into语句.

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

下面是我自己鼓捣出来的方法,希望对我和朋友有所帮助.

在Dao里写一个方法,让我们在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();

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: