• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
流白的日记
博客园    首页    新随笔    联系   管理    订阅  订阅

hibernate的强转类型

Query query1 = session.createSQLQuery("select count(*) from user u where u.name like ? ").setParameter(0, "%lis%") ;

Query query2 = session.createQuery("select count(*) from User ") ;

Sysstem.out.println((Long) query1.list().get(0)) ; //wrong

Sysstem.out.println((Long) query2.list().get(0)) ; //right

 

count(*)

count(*)是对不为null的行进行计数,因此某一行只要不是所有列都为null(即只要是存在的记录),就会被计数。

mysql用explain查看其执行计划,count(*)会尽量利用具有以下特征的索引来提高性能:

  1. not null列
  2. 字段较窄

 

count(field)

count(field)是对field列不为null的行进行统计,因此某一行的该列为null,则不予计数 。

同样用explain查看其执行计划,count(field)同样会尽量利用索引来提高性能,暂时发现有以下两种情况:

  1. 含有该field的索引
  2. 若改field为主键,则同count(*)一样,会选择更窄的索引,此时和使用count(*)无异

由此可见,用count(field)来进行统计会有以下问题:

  1. 若该field有null记录,意图用来统计所有记录时,结果是错误的
  2. 若该field没有索引或者不是最优索引,则效率会低
posted @ 2018-04-02 15:19  流白的日记  阅读(200)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3