zoukankan      html  css  js  c++  java
  • 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没有索引或者不是最优索引,则效率会低
  • 相关阅读:
    Spring----BeanPostProcessor
    spring lifeCycle
    lambda表达式
    mybatis ----SqlSessionManager
    带权随机
    Protocol Buffers学习笔记
    Java的Lambda表达式
    mysql之group_concat函数
    Java排序之归并排序
    Java排序之计数排序
  • 原文地址:https://www.cnblogs.com/df1151112630/p/8693682.html
Copyright © 2011-2022 走看看