Por que ORDER BY RAND() deixa a consulta lenta? Existe outra alternativa? – mysql random

Pergunta:


Eu tinha acabado de fazer perguntas a respeito de ordenação de valores randômicos através do MYSQL.

Daí comecei a notar uma incômoda lentidão no sistema sugestão de amizades aqui da empresa.

Eu uso o Laravel 3. Fui fazer uma checagem do que poder estar deixando o sistema lento.

Daí obtive os seguintes resultados numa consulta. Nos dois casos, estou usando LIMIT 10.

Com o RAND():

 85.203170776367
 6.6289901733398

Sem RAND()

0.074863433837891
0.11181831359863

Com é que o MYSQL utiliza o ORDER BY RAND() internamente – pra ficar tão lento?

Quais possíveis alterativas para obter os resultados no MYSQLrandomicamente.

Atualização

Fiz mais testes utilizando o MYSQL diretamente com o PhpMyAdmin.

Vejam.

Com RAND():

 SELECT * FROM pessoa ORDER BY RAND()
 #A mostrar registos de 0 - 29 (9024 total, O Query demorou 1.0453 sec)

Sem RAND():

SELECT * FROM pessoa ORDER BY id
#A mostrar registos de 0 - 29 (9024 total, O Query demorou 0.0008 sec)

Autor da pergunta Wallace Maxters

Resposta :

Ele demora porque ele funciona de uma maneira que precise gerar um número randômico para cada linha da tabela. Depois ele ordena essas linhas e retorna uma delas, de acordo com esses números randômicos.

Então, quanto mais linhas tiver sua tabela, mais vai demorar.

Uma alternativa seria reduzir o número de linhas a gerar esse número randômico.
Podes fazer isso limitando o número de linhas que você necessite, por exemplo 1 número seria LIMIT 1, e dividir pelo total de números da tabela,COUNT(*) e então multiplicar por 10 para evitar retornar menos linhas do que você precise.

SELECT * FROM tabela WHERE RAND()<(SELECT ((1/COUNT(*))*10) FROM tabela) ORDER BY RAND() LIMIT 1;

Vantagem: Fácil de usar em consultas complicadas e fácil de ajustar o número de linhas necessárias: bastar modificar o LIMIT numeroDesejado.

Desvantagem: o tempo de resposta ainda depende do número de linhas que você quer que retorne.

Não cheguei a testar, mas de acordo com o artigo de referência para essa resposta melhorou muito.

Referência: http://www.warpconduit.net/2011/03/23/selecting-a-random-record-using-mysql-benchmark-results/

Neste artigo ele apresenta outras alternativas com suas vantagens e desvantagens. Mas a escolhida como melhor alternativa foi esta exposta aqui pela sua melhor eficiência e facilidade de uso.

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *