Accueil > Forum > > > > Java : ouverture + rafraichissement + création base de données
Java : ouverture + rafraichissement + création base de données
mercredi 4 mars 2009 à 11:51:00 |
Java : ouverture + rafraichissement + création base de données

loic20h28
|
Bonjour tout le monde, Je réalise une petite application java en mode console qui intervient sur le SGBD FrontBase. Après plusieurs recherche, je vient vous demander de l'aide sur 3 choses car je n'arrive pas à trouver mon bonheur sur la toile. Tout d'abord j'ai trouvé ce code ('Existe-t-il une manière générique pour créer une BD avec JDBC ?') http://java.developpez.com/faq/jdbc/...divers#creerDB et je me demandé si cela était possible sous tout les SGBD?? Ensuite, 2 questions concernant la base de données : 1) Lorsque j'exécute mon programme, la première fois, il m'ouvre juste le SGBD, comment puis-je faire pour qu'il m'ouvre directement la base souhaité?? 2) Est-il possible via du code java de rafraichir la base de données?? Si oui, comment puis-je faire?? Voici un peu de mon code : import java.io.IOException; import java.sql.*; publicclass DictionnaireParametrable { publicstaticvoid main(String[] args) { System.out.print("\n Création des tables et insertions des données "); //ICI => Création de la base de données String url = "jdbc:FrontBase://localhost/DictionnaireParametrable_V3/user=_SYSTEM";
try { Class.forName("com.frontbase.jdbc.FBJDriver") .newInstance(); Connection con = DriverManager.getConnection(url);
Runtime runtime = Runtime.getRuntime(); Process process = null; try { Statement monStatement = con.createStatement();
System.out.println("\n\n************************************************************************************\n");
String table = "CREATE TABLE Article(id integer, libelle varchar(50), prix integer)"; monStatement.executeUpdate(table) ; String constraint = "ALTER TABLE Article ADD CONSTRAINT PK_Article PRIMARY KEY (id)"; monStatement.executeUpdate(constraint); System.out.println("Création de la table 'Article' avec succée");
String donnees = "INSERT INTO Article VALUES (1, 'Levis 501', 45)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (2, 'Sportwear', 12)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (3, 'Honda hornet', 1500)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (4, 'Suzuki bandit', 2000)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (5, 'Yamaha FZ6', 1000)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (6, 'Aprilia leonardo', 1250)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (7, 'C# précis et concis', 9)"; monStatement.executeQuery(donnees); donnees = "INSERT INTO Article VALUES (8, 'Tout sur le développement logiciel', 12)"; monStatement.executeQuery(donnees); System.out.println("Les données de la 'table Article' sont insérées");
// Ouverture du logiciel (du SGBD) process = runtime.exec(new String[]{"open", "/Applications/FrontBaseManager.app"});
// ICI => je veux ouvrir la base de données nommée "DictionnaireParametrable_V3" System.out.println("Pour continuer : cliquer sur la touche entrer de votre clavier"); int n = System.in.read();
System.out.println("\n************************************************************************************\n");
table = "CREATE TABLE TypeArticle(id integer, libelle varchar(30))"; monStatement.executeUpdate(table); constraint = "Alter TABLE TypeArticle ADD CONSTRAINT PK_TypeArticle PRIMARY KEY(id)"; monStatement.executeUpdate(constraint); System.out.println("Création de la table 'TypeArticle' avec succée");
donnees = "INSERT INTO TypeArticle VALUES (1, 'Pantalon(s)')"; monStatement.executeQuery(donnees); donnees = "INSERT INTO TypeArticle VALUES(2, 'Moto(s)')"; monStatement.executeQuery(donnees); donnees = "INSERT INTO TypeArticle VALUES(3, 'Livre(s)')"; monStatement.executeQuery(donnees); System.out.println("Les données de la table 'TypeArticle' sont insérées");
String modif_article = "ALTER TABLE Article ADD id_TypeArticle integer"; monStatement.executeUpdate(modif_article); String liaison = "ALTER TABLE Article ADD CONSTRAINT FK_Article_TypeArticle FOREIGN KEY (id_TypeArticle) REFERENCES TypeArticle(id)"; monStatement.executeUpdate(liaison); String modif_donnees = "UPDATE Article SET id_TypeArticle = 1 WHERE id = 1"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 1 WHERE id = 2"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 2 WHERE id = 3"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 2 WHERE id = 4"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 2 WHERE id = 5"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 2 WHERE id = 6"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 3 WHERE id = 7"; monStatement.executeUpdate(modif_donnees); modif_donnees = "UPDATE Article SET id_TypeArticle = 3 WHERE id = 8"; monStatement.executeUpdate(modif_donnees); System.out.println("Modifications de la table 'Article' sont apportées");
// Ouverture de l'application (vu que le SGBD est resté ouvert, il m'ouvre au niveau d'ou j'étais resté juste avant de retourner au code) process = runtime.exec(new String[]{"open", "/Applications/FrontBaseManager.app"});
//ICI => Rafraichissement de la base de données System.out.println("Pour continuer : cliquer sur la touche entrer de votre clavier"); n = System.in.read(); .............
Merci d'avance pour votre aide, vos conseils....
|
|
mercredi 4 mars 2009 à 14:34:28 |
Re : Java : ouverture + rafraichissement + création base de données

DARKSIDIOUS
|
Salut, Pour ta première question, ils le disent dès la première ligne : NON.
Il faut bien entendu que tu es un connecteur JDBC existant pour la base de données pour pouvoir créer une base avec JDBC...
JDBC n'est qu'une surcouche permettant de communiquer avec une base de données en Java. Et plus la base de données est utilisée, plus t'as de chance de trouver un connecteur JDBC complet et performant. Perso, j'ai utilisé les connecteurs MySQL, Oracle et DB2, et je ne leur ai pas trouvé de limitations, mais il est fort probable qu'avec des bases de données plus exotiques, tu ai moins de chances !
Sinon tes autres questions : 1/ "ouvre juste le SGBD" ??? C'est quoi pour toi "ouvrir le SGBD" ? L'interface graphique permettant de manipuler la base de données ? Un SGBD, ce n'est pas ce que tu as devant les yeux, mais le système de stockage des données, avec le système de requêtes (SQL ou autre), etc. C'est bien plus que la simple interface graphique ! 2/ "rafraichir la base de données", là encore, qu'est-ce que tu veux dire ??? Une base de données, c'est les données, ca n'a pas besoin d'être raffraîchit. Tu fais une requête d'insert ou d'update, et les données sont modifiées. Par contre, tu peux vouloir faire un refresh de tes données affichées dans une interfaces graphiques, et là, ben... c'est à toi de recharger les données qu'il faut quand il le faut... Tu n'a guère de choix ! ______________________________________ DarK Sidious
|
|
mercredi 4 mars 2009 à 14:55:59 |
Re : Java : ouverture + rafraichissement + création base de données

loic20h28
|
Bonjour,
merci de prendre de ton temps pour m'éclairer.
1/ "ouvre juste le SGBD" ??? C'est quoi pour toi "ouvrir le SGBD" ? L'interface graphique permettant de manipuler la base de données ? Un SGBD, ce n'est pas ce que tu as devant les yeux, mais le système de stockage des données, avec le système de requêtes (SQL ou autre), etc. C'est bien plus que la simple interface graphique ! => Par là je veux dire que lorsqu'avec mon code j'ouvre le logiciel FrontBase, il m'affiche la liste des base de données alors que moi je souhaiterais qu'il rentre directement dans la base nommée "DictionnaireParametrable".
2/ "rafraichir la base de données", là encore, qu'est-ce que tu veux dire ??? Une base de données, c'est les données, ca n'a pas besoin d'être raffraîchit. Tu fais une requête d'insert ou d'update, et les données sont modifiées. Par contre, tu peux vouloir faire un refresh de tes données affichées dans une interfaces graphiques, et là, ben... c'est à toi de recharger les données qu'il faut quand il le faut... Tu n'a guère de choix ! => En faite, voici les étapes de mon programme pour mieux expliquer ou est mon souci : * Création et remplissage de la première table * Ouverture de FrontBase * Visualisation (manuellement donc avec la souris....) du contenu et de la structure de la table * Création et remplissage de la deuxième table * On revient à la base * Visualisation -> là est mon problème car pour visualiser ma nouvelle table, je suis obligé de rafraichir la base donc un peu lourd. Y-a t'il moyen de le faire via du code java??
Merci d'avance en espérant être un peu plus clair.
|
|
mercredi 4 mars 2009 à 15:03:30 |
Re : Java : ouverture + rafraichissement + création base de données

DARKSIDIOUS
|
Salut, Ok, donc ce n'est pas la base de données en elle même que tu veux "raffraîchir", mais pouvoir piloter le logiciel FrontBase directement par du code Java.
Je ne suis pas sûr que ca soit possible en pur Java : piloter un logiciel par du code revient à simuler des événements souris ou des événements clavier, et pour cela, il faut certainement passer par du code C++ compilé en une dll (s'il s'agit d'un programme devant tourner sous windows) (donc dépendant de l'OS sur lequel on l'exécute !!!) et passer par un wrapper JNI pour piloter le tout en java. Bref, pas simple ! ______________________________________ DarK Sidious
|
|
mercredi 4 mars 2009 à 15:17:46 |
Re : Java : ouverture + rafraichissement + création base de données

loic20h28
|
ok merci pour tes renseignements.
Je crois bien que je vais laisser comme c'est car cela me parait bien trop compliqué.
Merci pour tout quand même
|
|
Cette discussion est classée dans : donnees, id, article, typearticle, monstatement
Répondre à ce message
Sujets en rapport avec ce message
troncature des mots sous java [ par malicia5 ]
bonjour,je suis à la recherche d'un code en java permettant de faire la lemmatisation des mots français et voilà ce que j'ai trouvé :<a href="http://b
sous struts 2 + jpa+ spring --> afficher un article d'une liste d'articles grace à son id ? [ par pokou03 ]
Bonjour,[^^happy17] je fais un wiki qui ressemble un peu à un CRUD sous Struts 2 + JPA/Hibernate + Spring. Dans ma .JSP qui affiche la liste de mes ar
JDBC [ par Armelkev ]
Bonjour les gars, je veux récupérer toutes les données de base et j'obtiens le message suivant: Ensemble de résultats épuisés. Mon code est le suivant
telechargement des donnees depuis un serveur web [ par sawsouch ]
Bonjour à tous les développeurs, je suis entrain de chercher une application en java qui permet de télécharger des données a partir du serveur web!
probleme avec les fichier xml [ par b00terry ]
salut les developpeur; je developpe une application en j2EE et j'ai besoin de stocker les donnees a partir d'une fichier xml dans une base de donnees
Afficher une JTable comprenant plusieurs table SQL [ par cedric774 ]
Bonjour à tous je suis occupé sur un projet java où j'utilise une base de données où je fais des ajouts, modifications, suppression et donc je voudra
calcul montant entre prix et quantité [ par paclemzo ]
dans mon formulaire facture jai un combobox ki liste l'ensemble des clients ki on effectué une commande je veu dire des k j clik sur une valeur du com
Hibernate : récuperer la date max [ par avg ]
Bonjour à tous, j'ai un table qui contient un ensemble d'article -chaque article peut avoir plusieurs date de mise en stock comment je peut récupér
Application avec JSF et les bases de donnees [ par aya2007 ]
Bonjour a tous [^^sad1] Je suis debutante dans le Jee je veux savoir comment utiliser une JSF pour traiter les donnees d'une table (ajout,supressin, a
Livres en rapport
|
Derniers Blogs
[SHAREPOINT] LES SESSIONS TECHDAYS 2012.[SHAREPOINT] LES SESSIONS TECHDAYS 2012. par Patrick Guimonet
Voici donc pour ceux qui n'ont pas pu venir, ou ceux qui n'ont pas pu toutes les suivre la liste des sessions SharePoint aux TechDays 2012, que je mettrais à jour dès que les liens des vidéo seront disponibles. Ou ici : http...
Cliquez pour lire la suite de l'article par Patrick Guimonet TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson
Forum
RE : CODE GéNéRé RE : CODE GéNéRé par am4sys
Cliquez pour lire la suite par am4sys RE : CODE GéNéRé RE : CODE GéNéRé par Julien39
Cliquez pour lire la suite par Julien39 CODE GéNéRé CODE GéNéRé par am4sys
Cliquez pour lire la suite par am4sys
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|