Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
boa tarde.. poderia me ajudar estou com um problema meu Join esta trazendo dados duplicados .
"SELECT *,date_format(`horasaida`,'%d-%m-%y às %Hh%i') FROM tb_entrada INNER JOIN tb_saida ON tb_entrada.nome = tb_saida.nome";
"SELECT *,date_format(`horasaida`,'%d-%m-%y às %Hh%i') FROM tb_entrada INNER JOIN tb_saida ON tb_entrada.nome = tb_saida.nome";
tenho 2 tabelas uma de entrada e uma de saida.. nao sei fazer somente em uma tabela nao consegui.. do jeito q ta ta funcionando mas no relatorio ae com o join se uma pessoa entrar e sair mais de 2 vezes no dia.. ele ta retornando os horarios q ele saiu a primeira vez , a segunda vez normal ae na terceira vez ele ja traz os resultados novamente .. nao sei onde ta errado ou que devo fazer pra nao duplicar mostrar somente os dados corretos.
--
-- Estrutura da tabela tb_entrada
--
CREATE TABLE IF NOT EXISTS `tb_entrada` (
`id` int(5) NOT NULL AUTO_INCREMENT,
`matricula` int(20) NOT NULL,
`tipo` varchar(30) CHARACTER SET latin1 NOT NULL,
`situacao` varchar(5) COLLATE utf8_unicode_ci NOT NULL,
`nome` varchar(50) CHARACTER SET latin1 NOT NULL,
`identidade` varchar(20) CHARACTER SET latin1 NOT NULL,
`placa` varchar(10) CHARACTER SET latin1 NOT NULL,
`veiculo` varchar(50) CHARACTER SET latin1 NOT NULL,
`cidade` varchar(50) CHARACTER SET latin1 NOT NULL,
`uf` varchar(2) CHARACTER SET latin1 NOT NULL,
`empresa` varchar(50) CHARACTER SET latin1 NOT NULL,
`dataentrada` varchar(15) COLLATE utf8_unicode_ci NOT NULL,
`horaentrada` varchar(20) COLLATE utf8_unicode_ci NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=15 ;
--
-- Estrutura da tabela tb_saida
--
CREATE TABLE IF NOT EXISTS `tb_saida` (
`id` int(5) NOT NULL AUTO_INCREMENT,
`nome` varchar(50) CHARACTER SET latin1 NOT NULL,
`horasaida` varchar(10) COLLATE utf8_unicode_ci NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=17 ;
meu Join e pro relatorio de entrada e saida,,, ele pega os dados de quem entrou na tabela entrada, data, e hora que entrou e pega a hora que ele saiu na tabela saida..
o pro que se a pessoa entrar mais de 3 vezes no dia o relatorio traz ele umas 6 vezes tipo as 3 que entrou e repete elas de novo..>
Agora, Alaerte Gabriel disse:
O que você quer não faz sentido. Pra quê você quer relacionar entrada e saída ? Faça um select para entradas e um para saídas. Não é necessário relacionamento aí.
seguinte, nao sei se entendeu.. eu nao sei fazer tudo rodar em uma so tabela,, dae criei 2 , a primeira qndo a pessoa entra ele cadastra na tabela de entrada os dados dele a data e hora que entrou.. ae ja a 2 tabela qndo ele sair vai pegar o nome de quem tinha entrado (nao sei se assim fica melhor) e registra a outra tabela a matricula, o nome e a hora que saiu.. dae esse join e pro relatorio de quem entrou e saiu pra pegar os dados da 1 tabela e depois juntar somente a hora de saida de cada pessoa.. nossa ficou complicado isso.. ja estou quebrando a cabeça faz dias.. ta funcionando mas se a mesma pessoa entrar por mais de 2 vezes no dia ele pega os dados da 1 a 2 a 3 e duplica tudo.. aff. teria uma maneira de fazer isso somente com uma tabela ? e como seria.É o que eu te disse. Isso foge do conceito de relacionamento de tabela. O que você está fazendo é "embolar" o meio de campo.
Se você já registro o nome na entrada e saída, não é necessário relacionamento, basta fazer um select normal para cada caso, não há nada de complicado nisso.
ta entao deixa ver se entendi a logica ae.. kkkkk
meu relatorio de entrada e saida..
matricula | nome | identidade | placa | veiculo | tipo de pessoa | Empresa | data entrada | hora de entrada | -> tabela 1 tb_entrada + o campo hora de saida | -> tabela 2 tb_saida..
o 1 select traria os dados da tabela 1 correto ?
o 2 select traria os dados da tabela 2 .. e como o select da tabela 2 vai saber quem saiu da tabela 1 ? isso q ta me matando a sem falar que nao pode duplicar.. se a pessoa entrar mais de 1 vez por dia teria que ir ficando um abaixo do outro.. .. olha meu relatorio funcionando.. www.polotextilinhumas.esy.es se pedir login: cleimar@hotmail.com senha: 123 testa pra tu ver.. se o script ficar 100% do jeito que quero vou disponibilizar pra todos.Leia um pouco sobre MODELAGEM DE DADOS e NORMALIZAÇÃO.
O que você quer não faz sentido. Pra quê você quer relacionar entrada e saída ? Faça um select para entradas e um para saídas. Não é necessário relacionamento aí.