FINDFIRST - MYSQL

SARAGIOTTO 07/09/2011 16:32:12
#383664
BOA TARDE
ESTOU MIGRANDO MEU SISTEMA DE ACCESS PARA MYSQL
E ESTOU SENTINDO A SEGUINTE DIFICULDADE
NO ACCESS EU USAVA MTO O FINDFIRST - FINDNEXT

EXEMPLO:

REC.FINDFIRST [Ô]CODIGO = 1[Ô]
DO WHILE NOT REC.NOMATCH
...
REC.FINDNEXT [Ô]CODIGO =2[Ô]
LOOP

COMO QUE EU FAÇO ISSO NO MYSQL?
OBRIGADO
MARCELO.TREZE 07/09/2011 19:03:22
#383669
Resposta escolhida
não use mais este tipo de consulta use sempre querys veja

Set RS = CNN. Execute([Ô]select * from suatabela where codigo = 1[Ô])
Do While Not RS.EOF
List1.AddItem RS!nome
RS.MoveNext
Loop


SACOFRITO 08/09/2011 08:02:34
#383677
Qual a desvantagem de se usar o find? Algumas vezs quando estou pessando linha por linha meu sistema noto uma demora, éessa a desvantagem?

PS: no mysql voce faz assim

ds.movefirst
ds.find [Ô]codigo = 1[Ô]
MARCELO.TREZE 08/09/2011 11:30:59
#383701
colega o findsirst, findnext são do quase exinto DAO, ja vi varias discuções a respeito do uso de DAO e ADO, quando o ADO é a conexão atual usada comumente em SGBDS mais robustos como MYSQL, SQLSERVER, FIREBIRD, em aplicações pequenas usando um ACCESS da vida, o DAO se mostra um pouco mais eficiente, mas com um banco de dados bem estruturado, vc terá um otimo desempenho usando ADO, estabilidade e confiabilidade, principalmente quando o banco atinger um tamanho significativo, o que não acontece com as tecnologias mais antigas(DAO com access), porém esta discução aqui no forum seria muito ampla com diversos pontos de vista, então minha sugestão final é: use ADO com QUERYS, mesmo que o desempenho seja MILIONÈSIMOS DE SEGUNDOS mais devagar, ainda assim vale a pena.
SARAGIOTTO 08/09/2011 12:00:42
#383708
maravilha gente, mto obrigado
deu certissimo
SARAGIOTTO 08/09/2011 12:05:07
#383709
agora tenho uma outra duvida qto ao mysql
no access eu usava sql assim:
SELECT * from tabela where tabela.data > data();
ou senao
SELECT DateDiff([Ô]d[Ô],[DATAVENCTO],Date()) FROM tabela;
Mas no mysql nao consegui fazer funcionar nem o DATA() nem O DATEDIFF
como devo fazer?
SACOFRITO 08/09/2011 12:06:19
#383710
Certo Marcelo, obrigado pela explicação.
Eu mesmo deixei de usar o find em todas as buscas, acho mais seguro tambem a query.


e SARGIOTTO, nao esqueça de pontuar quem mais lhe ajudou
SARAGIOTTO 08/09/2011 12:29:07
#383715
maravilha, e como eu uso o DATEDIFF?
MARCELO.TREZE 08/09/2011 13:26:40
#383719
seria assim

SELECT DATEDIFF(DATAVENCTO,CURDATE) FROM tabela

Página 1 de 2 [15 registro(s)]
Tópico encerrado , respostas não são mais permitidas