hibernate执行原生Sql语句的方法(转)
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();
}
}
相关文档:
1. 当前系统日期、时间
select getdate()
2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值
例如:向日期加上2天
select dat ......
SQL语句复制表的方法
(2009-08-29 13:41:54)
标签:
sql
分类:计算机知识
如果目的表已经存在:
insert into DATAHR.DBO.GBITEM
select * from DEMO.DBO.GBITEM
如果目的表不存在:
select * into DATAHR.DBO.GBITEM
from DEMO.DBO.GBITEM
跨库导入
select * into [zk_news].[dbo].[News1] from [zk_media].[ ......
Sql Server 中一个非常强大的日期格式化函数
Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM
Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06
Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16
Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06
Select CONVERT(varchar(100), GE ......
用EXPLAIN PLAN 分析SQL语句
http://blog.csdn.net/kj021320/archive/2006/08/19/1096021.aspx
如何生成explain plan?
解答:运行utlxplan.sql. 建立plan 表
针对特定SQL语句,使用 explain plan set statement_id = 'tst1' into plan_table
运行utlxplp.sql 或 utlxpls.sql察看explain plan
EXPLAIN PLA ......
--
聚合函数
use
pubs
go
select
avg
(
distinct
price)
--
算平均数
from
titles
where
type
=
'
business
'
go
use
pubs
go
select
max
(ytd_sales)
--
最大数
from
titles
go
use
pubs
go
select
min
(ytd_sales)
--
最小数
fr ......