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

本人水平浅劣,不足之处,批评就是了....

======================================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;
  }
 }

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安优小青和他的程序生活

我的文档对您有很大的帮助吗?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值