Preciso saber quais foram as ligações que não foram feitas na regra e as que foram feitas também, somente do dia!
Detalhe: As ligações normalmente são feitas alguns segundos depois de inserido na tb_historico_regras, então o horário pode ter um intervalo de 15 segundos.
O left join funciona sem a condição where, mas se eu tirar o where, ele vai buscar na tabela toda, tem 10 milhões de registros. Eu preciso só do dia.
Se eu colocar a condição dentro do left join, ele busca também todos os registros. Não sei como fazer.
Meu select ficou assim, porém não traz todos os resultados (os que tem datas diferentes), ainda não descobri uma forma.
------------=/-------------------
select m.numero, m.data as dataM, h.data as dataH, h.regra from tb_historico_regras h
left join tb_ligacoes m on (m.numero = h.numero and h.data between addtime(m.data, '-00:00:15') and addtime(m.data,'00:00:15'))
Pergunta
duezito
Pessoal, sou meio novato em MySql, normalmente procuro na net e acho a solução do que preciso.
Mas desta vez, ta complicado!
Problema:
Tenho 2 tabelas,
ligações (tb_ligacoes) e
histórico de regras (tb_historico_regras).
A tb_historico_regras pode inserir várias vezes o número, mas não necessariamente vai ser gravado um registro na tb_ligacoes.
Exemplo:
tb_ligacoes (numero, data)
4199999999 '2012-01-19 20:05:05'
4199999999 '2012-01-19 21:10:10'
tb_historico_regras (numero, data, regra)
4199999999 '2012-01-19 20:05:00' 1
4199999999 '2012-01-19 20:15:00' 1
4199999999 '2012-01-19 20:45:00' 1
4199999999 '2012-01-19 21:10:18' 1
Eu gostaria do resultado assim (numero, data_m, data_hist, regra):
4199999999 '2012-01-19 20:05:05' '2012-01-19 20:05:00' 1
4199999999 '2012-01-19 20:15:00' null null
4199999999 '2012-01-19 20:45:00' null null
4199999999 '2012-01-19 21:10:10' '2012-01-19 21:10:18' 1
Preciso saber quais foram as ligações que não foram feitas na regra e as que foram feitas também, somente do dia!
Detalhe: As ligações normalmente são feitas alguns segundos depois de inserido na tb_historico_regras, então o horário pode ter um intervalo de 15 segundos.
O left join funciona sem a condição where, mas se eu tirar o where, ele vai buscar na tabela toda, tem 10 milhões de registros. Eu preciso só do dia.
Se eu colocar a condição dentro do left join, ele busca também todos os registros. Não sei como fazer.
Meu select ficou assim, porém não traz todos os resultados (os que tem datas diferentes), ainda não descobri uma forma.
------------=/-------------------
select m.numero, m.data as dataM, h.data as dataH, h.regra from tb_historico_regras h
left join tb_ligacoes m on (m.numero = h.numero and h.data between addtime(m.data, '-00:00:15') and addtime(m.data,'00:00:15'))
where m.data > curdate();
------------=/-------------------
Desta forma, ele mostra somente assim:
4199999999 '2012-01-19 20:05:05' '2012-01-19 20:05:00' 1
4199999999 '2012-01-19 21:10:10' '2012-01-19 21:10:18' 1
Cadê os históricos que não tiveram ligações no horário??? :(
Espero ajuda! =/
Obrigado.
duezito ;)
Editado por duezitoLink para o comentário
Compartilhar em outros sites
0 respostass a esta questão
Posts Recomendados
Participe da discussão
Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.