一次线上Case,一条联合查询语句,直接在sql server查询分析器执行,1秒以内,通过java程序执行很慢要7秒返回结果
贴出sql 语句
select
temp.id,
temp.userId,
temp.operationUserId,
temp.filename
from
( select
RemoteOperationTab.userId,
RemoteOperationTab.id,
RemoteOperationTab.operationUserId,
OperatingPhotosRecord.filename,
ROW_NUMBER() OVER(
ORDER BY
RemoteOperationTab.id desc) as num
from
RemoteOperationTab
left join
OperatingPhotosRecord
on RemoteOperationTab.Id=OperatingPhotosRecord.RemoteOperationTabId
where
RemoteOperationTab.isDelete=0
and RemoteOperationTab.operationType in (
119,120,121
)
and OperatingPhotosRecord.OperaType in (
2,4,6,8
) ) temp
where
temp.num > 0
and temp.num<=20
order by
temp.id desc
一条联合查询语句,用Hibernate执行原生sql查询
在网上查说是Session session = getSessionFactory().openSession();这条语句问题,每次都打开新的session,导致耗时,
改成getCurrentSession获取session,一样很慢。
sql server有nvarchar类型,网上说是Hibernate,通过session.createSQLQuery(sql).addScalar方法查询,将nvarchar转String耗时,由于数据量太大不能将nvarchar转成varchar。
我就把所有nvarchar去掉,只留了int类型字段和varchar字段,但是发现还是慢,同事google的时候看到一个文章说varchar长度越长,越耗时,沿着这条思路找问题,果然找到了,原来filename字段长度是varchar(255),alert字段改成varchar(100)后,在查询果然快了。
总结,在使用sql server数据库时候,尽量不要使用nvarchar,并且varchar能用多少长度就设置多少,不要设置太长了
JAVA学无止境
谢谢大家关注