Jump to content
Sign in to follow this  
Insanity

Selecionar o id com maior número de registros

Recommended Posts

Então, suponhamos que tenha uma tabela com dados de um post. nessa tabela no mysql possui o id do post e o id do usuario. Eu queria fazer uma consulta que retorne o id do usuario que mais possui registros nessa tabela. Ou os 10 usuarios que mais possuem registros. Simples?

 

Agradeço desde já!

Share this post


Link to post
Share on other sites

Isso eu sei, por exemplo se eu quisesse trazer o número de registro de um id, isso eu saberia. Mas eu não quero colocar o id, eu quero trazer os ids dos usuarios que tem mais registros, tipo fazer um ranking, sabe?

 

 

Alguém me ajuda, é uma coisa aparentemente tão simples, e eu não acho o que eu quero no google...

Share this post


Link to post
Share on other sites
Na tabela:


Usuário x

id 1

TotalPosts 10


No caso, você fazeria uma consulta, dando order by no total de posts. E no insert desse post, você daria um update, incrementando o valor em 1, para indicar que ele fez um novo post.

Share this post


Link to post
Share on other sites

Então, eu já tenho uma tabela que tem o id do usuario e o id do post, lá nas estatisticas do usuário, para contar o número de post eu faço uma consulta a essa tabela e faço a soma de registro. Mas agora eu quero fazer um ranking, que listasse os usuários com maior número de posts, ou registros(da na mesma). Eu não sei como fazer uma busca que retorne os ids de usuario com maior número de resgistro. Eu até pensei em criar outra tabela, mas acredito(procuro) a melhor forma...

Share this post


Link to post
Share on other sites
$sql = mysql_query("SELECT * FROM tabela where (posts) > 10");

Ai você substitui o 10 pelo número de posts que deseja começar a listar. Caso não seja isso, um order by seria o suficiente. Por exemplo:

$sql = mysql_query("SELECT * FROM tabela order by (posts) DESC");

Share this post


Link to post
Share on other sites

Eu não sei como fazer uma busca que retorne os ids de usuario com maior número de resgistro. Eu até pensei em criar outra tabela, mas acredito(procuro) a melhor forma...

Você mesmo disse, dá na mesma. Você irá criar um campo com o número de posts, ou registros, que seja; depois precisará fazer um incremento à cada post do usuário, daí é só retornar com order by desc.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Similar Content

    • By samuel.huarachi
      Como o sistema da Yellow funciona?
      Como uma requisição no celular, destrava um patinete?

      Tem algum artigo na internet falando disso?
    • By geivisonsales
      Tenho um site sobre conteudos de entretenimento, e todos os posts tem uma imagem de fundo do tmdb, tem alguma maneira de otimizar o carregamento dessas imagens por url? ou alguma outra maneira?
    • By Salvatore
      Então, eu estou gravando uns dados no bancos de dados usando text area, mas quando eu dou espaço ou algo do tipo fica assim
       
      Ex :aaaa\r\naaaaaa\r\n
       
      onde esses \r\n são espaços e outras coisas, e ficam sendo exibidos quando eles retorna para a pagina
      alguém sabe como resolvo isso?
    • By violin101
      Caros amigos, saudações...
       
      Estou usando Codeigniter e estou com uma pequena dúvida.
       
      Tenho um Form com os seguintes campos:
      Data Início..... <input type="date" /> Hora Início.... <input type="time" /> Data Final..... <input type="date" /> Hora Final.... <input type="time" /> até aqui tudo bem
       
      Gostaria de fazer uma VERIFICAÇÃO para impedir que o usuário GRAVE no MySql uma data menor que a data atual.
      ou seja:
      Data Início nunca poderá ser menor que a Data Atual.
      e a
      Data Final só poder ser igual ou maior que a Data Início.
       
      Grato,
       
      Cesar
       
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.