데이터 베이스 MySQL 튜토리얼 MySQL查询随机数据的4种方法和性能对比_MySQL

MySQL查询随机数据的4种方法和性能对比_MySQL

Jun 01, 2016 pm 01:17 PM
장점과 단점

下面从以下四种方案分析各自的优缺点。
方案一:
SELECT * FROM `table` ORDER BY RAND() LIMIT 0,1;
这种方法的问题就是非常慢。原因是因为MySQL会创建一张零时表来保存所有的结果集,然后给每个结果一个随机索引,然后再排序并返回。
有几个方法可以让它快起来。
基本思想就是先获取一个随机数,然后使用这个随机数来获取指定的行。
由于所有的行都有一个唯一的id,我们将只取最小和最大id之间的随机数,然后获取id为这个数行。为了让这个方法当id不连续时也能有效,我们在最终的查询里使用”>=”代替”=”。
为了获取整张表的最小和最大id,我们使用MAX()和MIN()两个聚合函数。这两个方法会返回指定组里的最大和最小值。在这里这个组就是我们表里的所有id字段值。
方案二:
$range_result = mysql_query( " SELECT MAX(`id`) AS max_id , MIN(`id`) AS min_id FROM `table` ");
$range_row = mysql_fetch_object( $range_result );
$random = mt_rand( $range_row->min_id , $range_row->max_id );
$result = mysql_query( " SELECT * FROM `table` WHERE `id` >= $random LIMIT 0,1 ");
就像我们刚才提到的,这个方法会用唯一的id值限制表的每一行。那么,如果不是这样情况怎么办?
下面这个方案是使用了MySQL的LIMIT子句。LIMIT接收两个参数值。第一个参数指定了返回结果第一行的偏移量,第二个参数指定了返回结果的最大行数。偏移量指定第一行是0而不是1。
为了计算第一行的偏移量,我们使用MySQL的RAND()方法从0到1之间生成一个随机数。然后我们把这个数字跟我们用COUNT()方法获取倒的表记录数相乘。由于LIMIT的参数必须是int型而不能是float,我们使用FLOOR()来处理结果。FLOOR()会计算小于表达式的最大值。最终的代码就是这样:
方案三:
$offset_result = mysql_query( " SELECT FLOOR(RAND() * COUNT(*)) AS `offset` FROM `table` ");
$offset_row = mysql_fetch_object( $offset_result );
$offset = $offset_row->offset;
$result = mysql_query( " SELECT * FROM `table` LIMIT $offset, 1 " );
在MySQL 4.1以后我们可以使用子子查询合并上面两个方法:
方案四:
SELECT * FROM `table` WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM `table` ) ORDER BY id LIMIT 1;
这个方案跟方案二有同样的弱点,只对有唯一id值的表有效。
记住我们最初寻找选择随机行的替代方法的原因,速度!所以,这些方案的在执行时间上的比较会怎么样?我不会指出硬件和软件配置或者给出具体的数字。大概的结果是这样的:
最慢的是解决方案一(我们假定它用了100%的时间)。
方案二用了79%
方案三

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

시스템 구입 전 꼭 읽어야 할 내용: Win11과 Win10의 장단점 분석 시스템 구입 전 꼭 읽어야 할 내용: Win11과 Win10의 장단점 분석 Mar 28, 2024 pm 01:33 PM

오늘날의 정보화 시대에 개인용 컴퓨터는 우리 일상생활에 없어서는 안 될 도구로서 중요한 역할을 하고 있습니다. 컴퓨터의 핵심 소프트웨어 중 하나인 운영 체제는 사용 경험과 작업 효율성에 영향을 미칩니다. 시장에서는 Microsoft의 Windows 운영 체제가 항상 지배적인 위치를 차지해 왔으며 이제 사람들은 최신 Windows 11과 기존 Windows 10 중에서 선택해야 하는 상황에 직면해 있습니다. 일반 소비자의 경우 운영 체제를 선택할 때 버전 번호만 보는 것이 아니라 장점과 단점도 이해합니다.

템플릿의 장점과 단점은 무엇입니까? 템플릿의 장점과 단점은 무엇입니까? May 08, 2024 pm 03:51 PM

템플릿 작성: 장점과 단점 템플릿 작성은 재사용 가능한 코드 블록을 생성할 수 있는 강력한 프로그래밍 기술입니다. 이는 다양한 장점을 제공하지만 일부 단점도 제공합니다. 장점: 코드 재사용성: 템플릿을 사용하면 애플리케이션 전체에서 재사용할 수 있는 공통 코드를 생성하여 중복 및 유지 관리 노력을 줄일 수 있습니다. 일관성: 템플릿을 사용하면 코드 조각이 여러 위치에서 동일한 방식으로 구현되어 코드 일관성과 가독성이 향상됩니다. 유지 관리성: 템플릿에 대한 변경 사항은 이를 사용하는 모든 코드에 동시에 반영되므로 유지 관리 및 업데이트가 단순화됩니다. 효율성: 템플릿을 사용하면 동일한 코드를 반복해서 작성할 필요가 없으므로 시간과 노력이 절약됩니다. 유연성: 템플릿을 사용하면 다양한 애플리케이션 요구 사항에 쉽게 적용할 수 있는 구성 가능한 코드 블록을 만들 수 있습니다. 결점

Java Servlet 작동 방식의 장점과 단점은 무엇입니까? Java Servlet 작동 방식의 장점과 단점은 무엇입니까? Apr 16, 2024 pm 03:18 PM

JavaServlet은 동적 웹 페이지를 구축하는 데 사용되는 Java 클래스이며 클라이언트와 서버 간의 브리지 역할을 합니다. 작동 원리: 요청 수신, 서블릿 초기화, 요청 처리, 응답 생성 및 서블릿 닫기. 장점: 휴대 가능하고 확장 가능하며 안전하고 사용하기 쉽습니다. 단점: 오버헤드, 결합 및 상태 관리. 실제 사례: "Hello, Servlet!"을 표시하는 간단한 서블릿을 만듭니다.

Java 변수 이름을 지정할 때 중국어를 사용할 때의 장점과 단점 Java 변수 이름을 지정할 때 중국어를 사용할 때의 장점과 단점 Feb 18, 2024 am 10:14 AM

Java 변수 이름 지정에 중국어 사용의 장점과 단점 Java 프로그래밍에서는 일반적으로 영어를 사용하여 변수, 메서드, 클래스와 같은 식별자 이름을 지정합니다. 그러나 때로는 식별자의 일부로 중국어를 사용하는 것도 고려할 수 있습니다. 이 기사에서는 중국어로 명명된 Java 변수를 사용할 때의 장점과 단점을 살펴보고 몇 가지 구체적인 코드 예제를 제공합니다. 장점 1: 코드 가독성 향상. 중국어로 명명된 Java 변수를 사용하면 코드를 더 쉽게 이해하고 읽을 수 있습니다. 결국 우리 뇌는 영어보다 중국어를 더 자연스럽고 유창하게 이해하고 인식합니다. 영어가 아닌 경우

PHP 프레임워크의 장점과 단점 비교: 어느 것이 더 좋나요? PHP 프레임워크의 장점과 단점 비교: 어느 것이 더 좋나요? Jun 04, 2024 pm 03:36 PM

PHP 프레임워크의 선택은 프로젝트 요구 사항과 개발자 기술에 따라 다릅니다. Laravel: 기능이 풍부하고 커뮤니티가 활발하지만 학습 곡선이 가파르고 성능 오버헤드가 높습니다. CodeIgniter: 가볍고 확장하기 쉽지만 기능이 제한되고 문서가 적습니다. Symfony: 모듈식이며 강력한 커뮤니티이지만 복잡한 성능 문제가 있습니다. ZendFramework: 엔터프라이즈급이며 안정적이고 신뢰할 수 있지만 라이센스 비용이 크고 부피가 큽니다. 슬림(Slim): 마이크로 프레임워크로 빠르지만 기능이 제한되고 학습 곡선이 가파릅니다.

Golang 컴파일러 요약: 다양한 컴파일러의 장점과 단점 탐색 Golang 컴파일러 요약: 다양한 컴파일러의 장점과 단점 탐색 Jan 19, 2024 am 10:44 AM

Golang이 개발되면서 점점 더 많은 컴파일러가 개발되었습니다. 컴파일러를 선택할 때 개발자는 안정성, 성능, 사용 편의성 등과 같은 많은 요소를 고려해야 합니다. 이 기사에서는 몇 가지 일반적인 Golang 컴파일러를 요약하고 개발자가 자신에게 적합한 컴파일러를 더 잘 선택할 수 있도록 장점과 단점을 살펴봅니다. Go 공식 컴파일러 Go 공식 컴파일러는 Golang의 기본 컴파일러이자 Golang 커뮤니티에서 널리 인정받는 컴파일러입니다. 여기에는 다음과 같은 장점이 있습니다: 우수한 안정성, 작은 크기 및 편집

C 언어와 Python: 적용 가능한 시나리오 분석 및 장점과 단점 C 언어와 Python: 적용 가능한 시나리오 분석 및 장점과 단점 Mar 22, 2024 am 11:24 AM

C 언어 및 Python: 적용 가능한 시나리오 및 장단점 ​​분석 컴퓨터 프로그래밍 분야에서 C 언어와 Python은 각각 고유한 장점과 단점이 있으며 다양한 시나리오에 적합합니다. 이 기사에서는 C 언어와 Python에 대한 심층 분석을 수행하고 적용 가능한 시나리오, 장점 및 단점을 논의합니다. 1. C 언어 적용 시나리오: C 언어는 높은 효율성과 뛰어난 성능을 갖춘 프로세스 지향 프로그래밍 언어로 높은 수준의 제어와 효율성이 필요한 시스템 소프트웨어, 드라이버 및 임베디드 시스템 개발에 적합합니다.

솔리드 스테이트 드라이브와 기계식 하드 드라이브 비교 솔리드 스테이트 드라이브와 기계식 하드 드라이브 비교 Feb 26, 2024 pm 06:21 PM

솔리드 스테이트 드라이브(Solid State Drive)와 기계식 하드 드라이브의 장점과 단점 최근 몇 년 동안 솔리드 스테이트 드라이브(SSD)가 점차 일반 대중에게 공개되었으며 개인용 컴퓨터, 서버 및 기타 분야에서 널리 사용되고 있습니다. 이에 비해 기계식 하드디스크(HDD)는 전통적인 저장장치로서 신뢰성과 비용 효율성 측면에서도 장점이 있다. 이 기사에서는 독자가 자신의 필요에 맞는 저장 장치를 더 잘 선택할 수 있도록 솔리드 스테이트 드라이브와 기계식 하드 드라이브의 장점과 단점을 비교 분석합니다. 우선 솔리드 스테이트 드라이브는 읽기 및 쓰기 속도 측면에서 분명한 이점을 가지고 있습니다. SSD는 플래시 저장매체를 사용하기 때문에 읽기, 쓰기 속도가 더 빠릅니다.

See all articles