JAVA + ACCESS - Java - Programmation
Marsh Posté le 05-05-2004 à 22:00:33
n'hésitez pas à me dire si je ne suis pas assez clair, ou si vous avez besoin d'infos...
Marsh Posté le 06-05-2004 à 13:54:44
Citation : je ne parvient pas à insérer la variable "numeroetab" dans ma requete de mise a jour |
C'est quoi le problème ? Qu'est ce qui fait que tu n'y arrives pas ?
Marsh Posté le 06-05-2004 à 15:46:23
ben en fait il me sort que le type est incompatible alors que dans le code la variable est de type int et que dans la bdd c aussi une variable de type int le problème se situe la :
String updateString = "UPDATE ETABLISSEMENT " +
"SET nomet = '"+sNom+"' " +
"WHERE numet = '"+numeroetab+"'";
Marsh Posté le 06-05-2004 à 15:55:22
un nombre ca se met pas entre '', mets directement la valeur : "WHERE numet = "+numeroetab;
sinon, tu peux aussi utliser les PreparedStatement pour éviter de te prendre la tête avec ce genre de truc ...
Marsh Posté le 06-05-2004 à 19:03:14
ça maaaaaaaaaaaaarcheuuuuuuuu merci beaucoup sinon qi quelqu'un de courageux a une idee pour mon autre pb je suis toujours preneur mais merci beaucoup de ton aide benou
Marsh Posté le 06-05-2004 à 19:20:35
benou a écrit : un nombre ca se met pas entre '', mets directement la valeur : "WHERE numet = "+numeroetab; |
PreparedStatement putain!
Marsh Posté le 06-05-2004 à 19:25:06
c'etait vraiment indispensable les 400 lignes de code inutile
Marsh Posté le 06-05-2004 à 19:28:34
the real moins moins a écrit : c'etait vraiment indispensable les 400 lignes de code inutile |
c'est l'interface utilisateur, bien brouillée et greffé sur le code business
Marsh Posté le 06-05-2004 à 19:30:03
j'aime bien aussi le commentaire
//Constructeur/////////////////////////////////////////////////////////
au dessus de la definition de classe
et
//Methode/////////////////////////////////////////////////////////
au dessus du constructeur
(qui au passage est au milieu de 2 methodes)
Marsh Posté le 06-05-2004 à 19:36:38
les 2 zozos là, vous faites quoi à part critiquer ?
sinon, j'ai pas compris ton 1er problème ...
Marsh Posté le 06-05-2004 à 19:37:31
ReplyMarsh Posté le 06-05-2004 à 19:38:32
benou a écrit : les 2 zozos là, vous faites quoi à part critiquer ? |
bin lui dire d'utiliser un PreparedStatement au lieu de créer du SQL hardcodé, bourrain staÿle
Marsh Posté le 06-05-2004 à 19:41:54
DarkLord a écrit : bin lui dire d'utiliser un PreparedStatement au lieu de créer du SQL hardcodé, bourrain staÿle |
y a des façons plus normales de le dire
Marsh Posté le 06-05-2004 à 19:42:40
benou a écrit : y a des façons plus normales de le dire |
on est pas sa mère non plus
Marsh Posté le 06-05-2004 à 21:33:34
j'insiste sur le fait que je suis un newb's en JAVA, voir ça m'emmerde carrément dans la mesure ou j'aime pas ça (C++ powa)
Ensuite g mis tout le code de la classe pour que l'on evite de me demander des morceaux de code que je n'aurais pas mis.
Mes commentaires c n'importe koi, effectivement dans la mesure ou je suis en train de changer tout ce que je fais au fur et a mesure pour voir ce qui marche le mieux (quand ça marche) donc le commentaire ne correspond pas vraiment au code (voir pas du tout)
Enfin j'essaie effectivement les PreparedStatement sur vos conseils.
Maintenant que ceux qui s'y connaissent soit un peu constructifs et me dise exactement ce qu'il y a de bien dans le java (sans me sortir la grosse connerie de la compatibilité qui si elle est réelle, n'en reste pas moins tres contraignante)
Marsh Posté le 06-05-2004 à 22:01:50
frere tuck a écrit : n'en reste pas moins tres contraignante |
et les trolls sur les langages c'est pas dans ce topic
Marsh Posté le 06-05-2004 à 22:31:38
C t pas pour un troll c'était une réelle demande d'infos puisque je vois que vous vous y connaissez. M'enfin vous avez raison ce n'est peut être pas l'endroit pour ça.
Sinon j'ai appliquer vos conseils :
Code :
|
et lorsque je veux récupérer le numero de mon etablissement j'obtient :"etat de curseur non valide"
c'est toujours le meme message qu'auparavant et je ne comprend pas d'ou cela vient. Un ultime coup de main siouplait.
Marsh Posté le 06-05-2004 à 22:33:48
bah regarde dans la doc de ta base à quoi correspond cette erreur
Marsh Posté le 06-05-2004 à 23:04:20
ben soi disant que ce serait que je demanderai a lire une donnee qui n'existerai pas mais je ne suis pas plus avancé
Marsh Posté le 06-05-2004 à 23:07:37
EUH HA OUAIS
bon , tu vas relire la doc de ResultSet vite fait toi
ou au moins un tuto sur jdbc.
Marsh Posté le 06-05-2004 à 23:44:21
OUAI enfin la entre lire la doc de ma base et relire la doc de ResultSet y quand même une sacré différence.
Soit dit en passant il reste assez désagréable de demander des infos a des gens qui s'adresse à toi comme a un demeuré. Le coup de "tu vas relire la doc" (syndrome du "man" dès que tu poses une question a un connaisseur de linux) c un peu limite quand même, surtout quand j'ai bien spécifié que je suis un super débutant en JAVA.
Néanmoins j'ai mon info ce qui est un peu le principe de l'entraide sur des forums (certains ont tendance à l'oublier) alors je vous remercie pour votre aide (un peu agaçant quand même le coup du je le sais mais je te nargue) et pour m'avoir aiguiller dans mes recherche.
Marsh Posté le 07-05-2004 à 00:50:56
faut que tu fasse un next sur le resultset.
une resultset ca s'utilise habituellement dans un while (rs.next())
mais comme le dit moins moins, ce genre de truc se trouve dans n'importe quel tutorial jdbc
Marsh Posté le 07-05-2004 à 09:19:51
Merci Benou mais j'ai bien trouvé ma réponse, c'était effectivement un next dans un boucle while.
Je ne conteste pas que la solution se trouve dans une doc JDBC mais ce que je dis simplement c'est qu'il faut encore savoir ou chercher (et quand on est un newb c pas ça)
Marsh Posté le 07-05-2004 à 09:37:12
benou a écrit : mais comme le dit moins moins, ce genre de truc se trouve dans n'importe quel tutorial jdbc |
ouais mais c'est plus facile de venir le demander sur un forum, y'a des gens qui sont là et qui et que ça à foutre
Marsh Posté le 07-05-2004 à 23:02:15
Je clarifie une fois pour toute : dans mon cas je planche sur un projet en JAVA pour mon école... je suis donc un super noobs et quand j'ai un probleme du genre de celui que j'ai eu avec les curseurs, ça n'est pas que je poste un message parce que je suis trop paresseux pour chercher (car j'ai bel et bien fait des recherches) simplement je ne savais pas OU chercher. Dorénavant cette lacune est comblé. Si j'avais pu trouver la réponse sur google je l'aurai fait, j'aurai obtenu une réponse beaucoup plus vite alors dans la mesure ou on est déjà embeté par un probleme il reste assez peu agéable d'avoir l'impression qu'on se faout de sa gueule en plus. Maintenant il est vrai moins moins que si tu viens sur le forum uniquement pour etre non seulement peu constructif, mais en plus casse bonbon c'est réussi. Sur ce je cloture en vous remerciant pour votre aide.
Marsh Posté le 05-05-2004 à 21:19:08
Voila mon pb : je veux interfacer une base de donnees access avec une interface en java.
Donc pour le moment je me contente de coder les principales fonctions d'ajout/supression/modification.
Des informations concernant des etablissements sont affichés dans des zones de texte en fonction de l'établissement sélectionné (par son nom) dans une liste déroulante.
Lorsque ces informations sont affichées, un click sur le bouton modifier, permet de modifier l'enregistrement correspondant.
Mon premier problème est que lorsque je met à jour l'enregistrement je voudrais que le nom de l'établissement soit mis à jour.
Hors j'obtient le message suivant : "État de curseur non valide".
Mon second problème est que je ne parvient pas à insérer la variable "numeroetab" dans ma requete de mise a jour a la place de la valeur 6:
String updateString = "UPDATE ETABLISSEMENT " +
"SET nomet = '"+sNom+"' " +
"WHERE numet = 6";
Voila je m'excuse pour la naiveté de mes questions mais je suis débutant en JAVA.
Indication seule les fonctions : ItemStateChanged, recupdonnee, modif et recuptab sont concernés par mes problèmes.
PS : je code sous JBuilder et je vous joint le code complet de classe.