sql语句直接执行很快,java程序执行慢

一次线上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学无止境
谢谢大家关注

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值