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();
}
}
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();
}
}
相关文章推荐
- java---j2ee---hibernate执行原生Sql语句的方法
- 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题
- Laravel框架执行原生SQL语句及使用paginate分页的方法
- 使用 Hibernate 在 JPA 中 调用 generateSchema 会出现执行两次 SQL 语句问题的解决方法
- thinkPHP框架中执行原生SQL语句的方法
- Hibernate 执行原生sql语句字段名相同会被覆盖的问题
- hibernate 原生sql返回结果执行AddEntity方法
- thinkPHP框架中执行原生SQL语句的方法
- 关于使用JdbcTemplate封装的方法执行原生sql语句的常用写法
- hibernate4中使用createSQLQuery方法执行sql语句的用法
- 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题
- Hibernate中执行SQL语句的方法(转)
- 使用Hibernate 5.0、4.0、3.0 createSQLQuery执行原生Sql语句 遇到问题及解决办法集锦
- hibernate 原生sql返回结果执行AddEntity方法
- Hibernate执行原生的sql语句
- 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题 .
- hibernate 原生sql返回结果执行AddEntity方法
- 在SSH2开发平台下利用Hibernate Session对象执行原生Sql语句
- 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题
- weblogic hibernate关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题(www.50xiao.com)