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(*)会尽量利用具有以下特征的索引来提高性能:
- not null列
- 字段较窄
count(field)
count(field)是对field列不为null的行进行统计,因此某一行的该列为null,则不予计数 。
同样用explain查看其执行计划,count(field)同样会尽量利用索引来提高性能,暂时发现有以下两种情况:
- 含有该field的索引
- 若改field为主键,则同count(*)一样,会选择更窄的索引,此时和使用count(*)无异
由此可见,用count(field)来进行统计会有以下问题:
- 若该field有null记录,意图用来统计所有记录时,结果是错误的
- 若该field没有索引或者不是最优索引,则效率会低