MySQL查询随机数据的4种方法和性能对比_MySQL
下面从以下四种方案分析各自的优缺点。
方案一:
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%
方案三

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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

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

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

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

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

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

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