dihao26018 2009-08-04 11:43
浏览 1415
已采纳

关于Hibernate hql中IS NULL和IS NOT NULL语句的替代问题

今天看到应该尽量避免使用IS NULL和IS NOT NULL,理由如下:

Where字句中的IS NULL和IS NOT NULL将不会使用索引而是进行全表搜索,因此需要通过改变查询方式,分情况讨论等方法,去掉Where子句中的IS NULL和IS NOT NULL。

请问这两个语句有什么不影响效率的语句或方法来进行替代吗?
[b]问题补充:[/b]
有时候,IS NULL语句是不可避免的,handonghandong所提的是不是通过Hibernate分批次取出数据,比如每次取100条,避免全表搜索的出现?

但我想问的是在全表进行搜索,取出所有name为空的记录,如果使用IS NULL的话,对这个表所建的索引就会失效,请问有没有什么语句可以替代呢?

  • 写回答

2条回答 默认 最新

  • web_killer 2009-08-04 21:44
    关注

    首先若是全表搜索的话,如果表中数据很多,我建议分页,这样可以提高效率
    若在一张表中的话,我认为效率可能不会太高太大,毕竟hql语句执行where还是在前面的,还有就是你可以使用Query接口试试呢

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 YOLO检测微调结果p为1
  • ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题