用distinct来返回不重复的用户名:select distinct name from user,结果为:
这样只把不重复的用户名查询出来了,但是用户的id,并没有被查询出来:select distinct name,id from user,这样的结果为:
distinct name,id 这样的mysql 会认为要过滤掉name和id两个字段都重复的记录,如果sql这样写:select id,distinct name from user,这样mysql会报错,因为distinct必须放在要查询字段的开头。
所以一般distinct用来查询不重复记录的条数。
如果要查询不重复的记录,有时候可以用group by :
select id,name from user group by name
首先对于MySQL的DISTINCT的关键字的一些用法:1.在count不重复的记录的时候能用到,比如SELECTCOUNT(DISTINCTid)FROMtablename;就是计算talbebname表中id不同的记录有多少条。2,在需要返回记录不同的id的具体值的时候可以用,比如SELECTDISTINCTidFROMtablename;返回talbebname表中不同的id的具体的值。3.上面的情况2对于需要返回mysql表中2列以上的结果时会有歧义,比如SELECTDISTINCTid,typeFROMtablename;实际上返回的是id与type同时不相同的结果,也就是DISTINCT同时作用了两个字段,必须得id与tyoe都相同的才被排除了,与我们期望的结果不一样。4.这时候可以考虑使用group_concat函数来进行排除,不过这个mysql函数是在mysql4.1以上才支持的。5.其实还有另外一种解决方式,就是使用,SELECTid,type,count(DISTINCTid)FROMtablename,虽然这样的返回结果多了一列无用的count数据(或许你就需要这个我说的无用数据),返回的结果是只有id不同的所有结果和上面的4类型可以互补使用,就是看你需要什么样的数据了。DISTINCT的效率:SELECTid,type,count(DISTINCTid)FROM tablename虽然这样的返回结果多了一列无用的count数据(或许你就需要这个我说的无用数据),SELECTid,typefromtablenamegroupbyid这样貌似也可以,用distinct的时候,如果它有索引,mysql会把它转成groupby的方式执行。 MySQL数据库对于COUNT(*)的不同处理会造成不同的结果,比如,执行:SELECTCOUNT(*)FROMtablename即使对于千万级别的数据mysql也能非常迅速的返回结果。 执行:SELECTCOUNT(*)FROMtablenameWHERE…..mysql的查询时间开始攀升。 网上查资料得知:当没有WHERE语句对于整个mysql的表进行count运算的时候,MyISAM类型的表中保存有总的行数,而当添加有WHERE限定语句的时候Mysql需要对整个表进行检索,从而得出count的数值,因此加上where条件的查询速度就会很慢了。以上关于MySQL数据库的distinct以及count(*)的使用就介绍到这里了,希望本次的介绍能够带给您一些收获。MysQL中的两个谓词distinct和limit,它们的作用是LIMIT是MySQL内置函数,其作用是用于限制查询结果的条数。
LIMIT子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须。
是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回。
记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句。
使用说明:
1、如果是用 MySQL + Apache,使用的又是 FreeBSD 网络 *** 作系统的话,安装时候你应按注意到FreeBSD的版本问题。
在 FreeBSD 的 3.0 以下版本来说,MySQL Source 内含的 MIT-pthread 运行是正常的,但在这版本以上,你必须使用 native threads,也就是加入一个 with-named-thread-libs=-lc_r 的选项。
2、如果在 COMPILE 过程中出了问题,请先检查你的 gcc版本是否在 2.81 版本以上,gmake 版本是否在3.75以上。
3、如果不是版本的问题,那可能是你的内存不足,请使用 ./configure--with-low-memory 来加入。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)