• mysql细节问题


    1. 

    select count(*) 与 select count(1)区别?

    原帖由 yangfei080 于 2008-5-8 14:19 发表 
    我知道:
    select   count(*)是统计表中所有记录个数 
    而select   count(1)是返回首行
    后者的效率比前者要高

    请问:
    达人们能够解释下两者oracle内部实现的区别?
    感谢!



    楼主理解错了,select count(1) 可不是返回首列行数
    其原理是对数字1进行统计,会将表中所有记录转化为1,然后再计数统计
    相当于先select 1 from table 然后count

    跟表结构有关系:
    如果表中没有主键,那么count(1)比count(*)快
    如果有主键,那么count(主键,联合主键)比count(*)快
    如果表中只有一个字段,count(*)最快

    2.

    MYSQL中LIMIT用法

    limit是mysql的语法
    select * from table limit m,n
    其中m是指记录开始的index,从0开始,表示第一条记录
    n是指从第m+1条开始,取n条。
    select * from tablename limit 2,4
    即取出第3条至第6条,4条记录

    mysql> SELECT * FROM table LIMIT 5,10;  // 检索记录行 6-15

    //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1: 
    mysql
    > SELECT * FROM table LIMIT 95,-1// 检索记录行 96-last.

    //如果只给定一个参数,它表示返回最大的记录行数目: 
    mysql
    > SELECT * FROM table LIMIT 5;     //检索前 5 个记录行

    //换句话说,LIMIT n 等价于 LIMIT 0,n。
  • 相关阅读:
    Leetcode_02【两数相加】——【难度:中】
    Leetcode_39【组合总和】
    Leetcode_38【报数】
    Leetcode_36【有效的数独】
    Leetcode_35【搜索插入位置】
    51nod1347 旋转字符串
    WebH
    ExcelHelper
    文件二进制与String相互转换
    汇编语言里 eax, ebx, ecx, edx, esi, edi, ebp, esp
  • 原文地址:https://www.cnblogs.com/GODYCA/p/3106153.html
Copyright © 2020-2023  润新知