JAVA : Requêtes CRUD (Classes DAO)
Monday, June 6, 2011     17:19
  • Mon @ IP: 54.162.4.139



retour

Poster un commentaire ou une réponse

Requêtes CRUD (Classes DAO)

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 11:42:39

Chaque classe DAO contient les méthodes de liaison avec la base de données, appelées CRUD (pour Create, Request, Update, Delete).


On va voir un exemple pour chaque requête

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:07:51

On va continuer avec l'exemple de la discussion suivante:
http://www.lesdeveloppeurs.net/Java-connexion-a-la-base-de-donnee-DAO--236

On crée dans notre base de donnée une table "user" ayant "userid" et "name" comme colonne
et On ajoute le package Domain dans notre projet. dans "Domain" on ajoute la classe User qui contient ce code:

package Domain;
public class User {
private int id;
private String name;

public User() {
// TODO Auto-generated constructor stub
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

}

On ajoute un package "DAO" quiva contenir les classes DAO qu'on verra par la suite

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:11:17

On ajoute la classe "UserDao" dans le pckage DAO et on insère le code suivant:

package DAO;


import java.sql.Statement;

import Domain.User;
import Util.MyConnectionMysql;

public class UserDao {
private static Statement statement = MyConnectionMysql.giveMeStatement();

}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:13:05

---------------CREATE---------------

On va voir comment insérer (créer) une ligne dans notre table:

Voici le code d'insertion dans la table a mettre dans la classe "UserDao"

public static boolean addUser(User user) {
boolean b = false;

try {
String sql = "insert into user (name) values ('" + user.getName()
+ "')";
System.out.println(sql);
statement.executeUpdate(sql);
System.out.println("user added ...");
b = true;

} catch (Exception e) {
System.err.println("problem in insertion ...");
}
return b;
}


Publicité

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:14:44

---------------DELETE---------------


Voici le code de suppression d'une ligne de la table a mettre dans la classe "UserDao"


public static boolean deleteUser(User user) {
boolean b = false;

try {
String sql = "delete from user where userid='" +user.getId()+"'";
System.out.println(sql);
statement.executeUpdate(sql);
System.out.println("User deleted ...");
b = true;

} catch (Exception e) {
System.err.println("problem in deleting ...");
}
return b;
}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:26:48

------------REQUEST-------------

Voici le code de sélection (affichage) de toute la table (a mettre dans la classe "UserDao")

public static void showUsers() {
boolean b = false;

try {
String sql="select * from user";
System.out.println(sql);

System.out.println("Selection users ...");

ResultSet resultSet =statement.executeQuery(sql);
while(resultSet.next())
{
System.out.print(resultSet.getString("userid")+"\t");
System.out.print(resultSet.getString("name")+"\t");


System.out.println("");
}

} catch (Exception e) {
System.err.println("problem in insertion ...");
}

}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:33:24

------------UPDATE-------------

Voici le code de modification d'une ligne de la table (a mettre dans la classe "UserDao")

public static void update(int id ,String name)
{
String sql="update user set name='"+name+"' where userid="+id+"";
int nblignesaffectees = 0;
try {
nblignesaffectees = statement.executeUpdate(sql);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(nblignesaffectees);

}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:38:39

On veut tester nos fonction.

On ajoute les classes suivantes (avec leurs codes) sous le package "Mains" et on exécute

------Ajout:

package Mains;

import DAO.UserDao;
import Domain.User;

public class TestAddUser {
public static void main(String[] args) {
User user = new User();
user.setName("fff");
System.out.println(UserDao.addUser(user));
}
}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:39:04

--------------Suppression

package Mains;

import DAO.UserDao;
import Domain.User;
public class TestDeleteUser {

public static void main(String[] args) {
User u=new User();
u.setId(1);
u.setName("les dev");
UserDao.deleteUser(u);
UserDao.showUsers();
}
}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:39:32

--------REQUEST

package Mains;

import DAO.UserDao;
import Domain.User;
public class TESTshowUsers {

public static void main(String[] args) {
UserDao.showUsers();
}
}


Publicité

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:40:12

-----------Update (modification)

package Mains;

import DAO.UserDao;
import Domain.User;

public class Testupdateuser {
public static void main(String[] args) {

UserDao.update(1, "les dev");
UserDao.showUsers();
}
}

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:40:23

Voici le projet:

  abdou1987 :
nb posts:722
nb discussions:131
inscrit le :02-12-2014
le 30-01-2015 à 12:42:06

Projet-DAO.rar

Poster un commentaire ou une réponse :
Poster
     Ajouter un document à la discussion:
       

Actualité informatique et High-Tech

16-10-2015               lire

Dropbox propose aussi un outil d'écriture collaborative à son service

16-10-2015               lire

Bientôt des DRM dans des JPEG

17-04-2015               lire

Google propose une requête pour retrouver son téléphone

17-04-2015               lire

Youtube prépare une offre payante sans publicité

17-04-2015               lire

Sony Pictures : Des milliers de mails et documents confidentiels dévoilés

07-04-2015               lire

T411 bloqué par les FAI français

07-04-2015               lire

NVIDIA publie un pilote correctif et met à jour SHIELD Hub ainsi que GeForce Experience

07-04-2015               lire

Linkedin acquiert la start-up Refresh

03-04-2015               lire

Chromebit, la clé USB Google et Asus qui transforme n’importe quel écran en ordinateur

03-04-2015               lire

Une personne aurait pu supprimer toutes les vidéos d’une chaine Youtube en quelques secondes

03-04-2015               lire

Firefox 37 apporte un cryptage complémentaire à HTTPS

03-04-2015               lire

Windows XP, ce système qui ne veut pas mourir

02-04-2015               lire

Piratage de Labio.fr : le laboratoire répond à nos questions et ne payera pas la rançon

02-04-2015               lire

AWS lance des instances géantes avec 48 To de stockage

02-04-2015               lire

WhatsApp ajoute les appels gratuits et illimités à son application

31-03-2015               lire

Nadim Kobeissi : de Cryptocat à Peerio, du piratage au doctorat

31-03-2015               lire

L'Université de Nantes inaugure son datacenter modulaire taillé pour le HPC

31-03-2015               lire

GitHub victime d’une attaque DDoS majeure

27-03-2015               lire

Googlinette : les recherches de Google en devinettes

27-03-2015               lire

F8 : Facebook ouvre Messenger au e-commerce

27-03-2015               lire

À la SNCF, une fuite de données simple comme une touche F5

23-03-2015               lire

Des satellites GPS de Boeing affectés par une erreur technique

23-03-2015               lire

Plus de 700 000 routeurs ADSL vulnérables au piratage

23-03-2015               lire

Twitter sous le coup d’une action collective pour discrimination

22-03-2015               lire

Les montres connectées étaient déjà présentes dans les films, séries et dessins animés

22-03-2015               lire

Une Audi autonome va traverser les USA de SF à New York

20-03-2015               lire

Éclipse du Soleil : comment la suivre en direct sur Internet

20-03-2015               lire

Projet Leap : des bus 2.0 à San Francisco

20-03-2015               lire

Nvidia dévoile Drive PX, un système de conduite autonome

17-03-2015               lire

Embarquez pour Apollo 11, expérience virtuelle hors du commun

16-03-2015               lire

Ce jour où Google a exposé les données de 282 867 domaines

16-03-2015               lire

Yahoo publie le code de son plug-in de chiffrement mail

16-03-2015               lire

Après un an sans mise à jour, HAWKEN revient à la vie

12-03-2015               lire

Le big data au service du séquençage ADN pour accélérer les diagnostics

12-03-2015               lire

Clap de fin pour PlayStation Mobile

12-03-2015               lire

Apple : retour à la normale après une panne de plus de 11 heures

12-03-2015               lire

Ericsson va supprimer 2 200 postes en Suède

12-03-2015               lire

Le plan de Fleur Pellerin contre le piratage sur Internet

10-03-2015               lire

Apple Watch, Watch Edition et Watch Sport : de 399 à 18.000 euros !

10-03-2015               lire

Apple présente le “nouveau MacBook” qui remplace le MacBook Air

09-03-2015               lire

Google développe une version d'Android pour la réalité virtuelle

09-03-2015               lire

Quand la MPAA demande à Google de déréférencer son propre site

09-03-2015               lire

Heroes of the Dorm : un tournoi HotS avec 450 000 $ de bourses d'études à gagner

09-03-2015               lire

1 milliard d'adresses mails volées, 2 pirates inculpés

09-03-2015               lire

VMware accusé de violation de code Linux

09-03-2015               lire

Les drones civils bientôt immatriculés ?

05-03-2015               lire

7 sites qui permettent d’envoyer des fichiers de + ou – 2 Go

04-03-2015               lire

Smartphones : Apple passe en tête devant Samsung56% des consommateurs inquiets pour leurs données en Europe

04-03-2015               lire

Smartphones : Apple passe en tête devant Samsung

04-03-2015               lire

MWC 2015 : Onevisage pésente un scan facial 3D pour smartphones

04-03-2015               lire

Caméras sportives : Xiaomi s'attaque au monopole GoPro

04-03-2015               lire

Yi Camera, la caméra embarquée de Xiaomi à moins de 60€

04-03-2015               lire

Faille FREAK : quand des connexions SSL/TLS se contentent d'un chiffrement RSA sur... 512 bits

04-03-2015               lire

Bientôt des pubs sur Google Play (Android)

28-02-2015               lire

En partenariat avec "Positive Technologies", Esprit a l'honneur d'inviter ses étudiants à la 1ère édition de l’événement ESPRIT HACK DAYS dans les locaux d'ESPRIT Chotrana 2 et ce le 03 et le 04 Mars 2015.

28-02-2015               lire

La direction des stages d’ESPRIT et Ernst & Young ont le plaisir d'inviter ses étudiants à la journée de l’entreprise du mercredi 4 mars 2015 dans la salle E5 d’ESPRIT Factory.

25-02-2015               lire

Adobe fête les 25 ans de son logiciel Photoshop

25-02-2015               lire

Linux 4.0 : gros numéro et petite version

Haut de page.