IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

Ajouter données dans une base de données


Sujet :

Android

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Points : 132
    Points
    132
    Par défaut Ajouter données dans une base de données
    Bonjour,

    J'ai un fichier xml que je doit lire, je l'ai fait sauf que cela m'affiche d'abord mes deux livraisons et ensuite mes trois colis, sa ne fait pas les référence avec la première livraison avec ses deux colis et seconde avec son colis. Je souhaiterait maintenant enregistrer ces donnée dans une base de donnée SQLite mais je ne vois pas trop comment faire.

    Voici le fichier xml:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <livraisons>
      <livraison>
        <client>Mme Lagrange</client>
        <adresse>28 rue des Rainettes 33150 Cenon</adresse>
        <colis>
          <ref>172648574</ref>
          <montant>96.00</montant>
        </colis>
        <colis>
          <ref>172648586</ref>
          <montant>45.80</montant>
        </colis>
      </livraison>
      <livraison>
        <client>M. Iribarne</client>
        <adresse>5 chemin des Dunes 33510 Andernos</adresse>
        <colis>
          <ref>172648588</ref>
          <montant>146.75</montant>
        </colis>
      </livraison>  
    </livraisons>
    Ma classe livraison:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    public class Livraison {
     
    	private String client;
    	private String adresse;
     
    	public Livraison(String client, String adresse) {
    		this.client = client;
    		this.adresse = adresse;
    	}
     
    	public Livraison(){
    		super();
    	}
     
    	public String getClient(){
    		return client;
    	}
     
    	public String getAdresse(){
    		return adresse;
    	}
     
    	public void setClient(String client) {
    		this.client = client;
    	}
     
    	public void setAdresse(String adresse) {
    		this.adresse = adresse;
    	}
     
    	public String toString(){
    		return "Livraison : client : "+client+" => adresse : "+adresse;
    	}
    }
    Ma classe Colis:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    public class Colis {
     
    	private String ref;
    	private double montant=0;
    	private Livraison idLivraison;
     
    	public Colis(Livraison idLivraison, double montant, String ref) {
    		super();
    		this.idLivraison = idLivraison;
    		this.montant = montant;
    		this.ref = ref;
    	}
     
    	public Colis(){
    		super();
    	}
     
    	public double getMontant() {
    		return montant;
    	}
     
    	public Livraison getIdLivraison() {
    		return idLivraison;
    	}
     
    	public String getRef(){
    		return ref;
    	}
     
    	public void setRef(String ref) {
    		this.ref = ref;
    	}
     
    	public void setMontant(long montant) {
    		this.montant = montant;
    	}
     
    	public String toString(){
    		return "Colis : référence : "+ref+" => montant : "+montant;
    	}
    }
    Ma classe GestionBD:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    public class GestionBD {
    	private SQLiteDatabase maBase;
    	private BdHelper monBdHelper;
     
     
    	public GestionBD(Context context) {
    		monBdHelper = new BdHelper(context, "baseLivraison", null, 1);
    		init();
    	}
     
    	public void init(){
    		long id;
    		Livraison uneLivraison;
    		Colis unColis;
    		open();
     
    		uneLivraison = new Livraison();
    		id = ajouteLivraison(uneLivraison);
    		unColis = new Colis();
    		ajouteColis(unColis, id);
    		close();
     
    	}
    	public void open(){
    		maBase = monBdHelper.getWritableDatabase();
    	}
    	public void close(){
    		maBase.close();
    	}
    	public long ajouteLivraison(Livraison livraison){
    		ContentValues v = new ContentValues();
    		v.put("client", livraison.getClient());
    		v.put("adresse", livraison.getAdresse());
    		return maBase.insert("livraison", null, v);
    	}
    	public void ajouteColis(Colis colis, long id){
    		ContentValues v = new ContentValues();
    		v.put("idlivraison", id);
    		v.put("ref", colis.getRef());
    		v.put("montant", colis.getMontant());
    		maBase.insert("colis", null, v);
    	}
    	public void supprimeLivraisons(){
    		maBase.delete("livraison", null, null);
    	}
    	public ArrayList<String> donneLivraisons(){
    		ArrayList<String> liste = new ArrayList<String>();
    		Cursor c = maBase.rawQuery("select id, client, adresse from livraison order by client",null);
    		while (c.moveToNext())
    			liste.add( c.getString(0)+" "+c.getString(1)+" "+c.getString(2));
    		return liste;
    	}
    	public ArrayList<String> donneColis(){
    		ArrayList<String> liste = new ArrayList<String>();
    		Cursor c = maBase.rawQuery("select client, sum(montant) as montant from livraison" +
    				" left outer join colis on id=idlivraison group by id order by client",null);
    		while (c.moveToNext()) liste.add(c.getString(0)+" "+c.getDouble(1));
    		return liste;
    	}
    }
    Ma classe BD helper:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    public class BdHelper extends SQLiteOpenHelper {
     
    	public BdHelper(Context context, String name, CursorFactory factory,
    			int version) {
    		super(context, name, factory, version);
    		// TODO Auto-generated constructor stub
    	}
    	@Override
    	public void onCreate(SQLiteDatabase db) {
    		// TODO Auto-generated method stub
    		String req = "create table livraison(id integer primary key autoincrement, client text, adresse text)";
    		db.execSQL(req);
    		req = "create table colis(ref text, montant real, idlivraison integer, foreign key (idlivraison) references livraison(id))";
    		db.execSQL(req);
    	}
    	@Override
    	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    		// TODO Auto-generated method stub
    	}
    }
    Classe MaSaxHandler:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    public class MaSaxHandler extends DefaultHandler {
     
    	   private Livraison livraison;
    	   private List<Livraison> lesLivraisons = new ArrayList<Livraison>();
    	   private Colis colis;
    	   private List<Colis> lesColis = new ArrayList<Colis>();
    	   private String valeur;
     
    	   public void parse(InputStream is) throws ParserConfigurationException, SAXException, IOException{
    		   SAXParserFactory factory = SAXParserFactory.newInstance();
    		   SAXParser parser=factory.newSAXParser();
    		   parser.parse(is,this);
    	   }
    	   public void startElement( String uri, String localName, String qName, Attributes attributes)
    			   throws SAXException {
    		   if (localName.equals("livraison"))  livraison = new Livraison();
    		   if (localName.equals("colis")) colis = new Colis();
    	   }
    	   public void characters(char[] ch,int start, int length) throws SAXException{
    			valeur = new String(ch,start,length);
    		}
    	   public void endElement( String uri, String localName,String qName) throws SAXException {
    	        if (localName.equals("livraison")) {
    	        	lesLivraisons.add(livraison);
    	        }else if (localName.equals("client")){
    	        	livraison.setClient(valeur);
    	        }else if (localName.equals("adresse")){
    	        	livraison.setAdresse(valeur);
    	        }else if (localName.equals("colis")){
    	        	lesColis.add(colis);
    	        }else if (localName.equals("ref")){
    	        	colis.setRef(valeur);
    	        }else if (localName.equals("montant")){
    	        	long monLong=Long.parseLong("valeur");
    	        	colis.setMontant(monLong);
    	        }
    	    }
    	   public List<Livraison> getLesLivraisons() {
    		   return lesLivraisons;
    	   }
     
    	   public List<Colis> getLesColis() {
    			return lesColis;
    	   }
    }
    Mon fichier xml se trouve sur un serveur web et j'ai réussi a y accéder

    Merci de votre aide

  2. #2
    Débutant  
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Points : 132
    Points
    132
    Par défaut
    help me!

  3. #3
    Débutant  
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Points : 132
    Points
    132
    Par défaut
    help !!!

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Si tu veux lier tes colis à tes livraisons, il faut déjà avoir une liste de colis dans la class livraison. Après c'est juste une question d'ajouter les colis que tu parse dans la livraison en cours.

Discussions similaires

  1. [Débutant] Ajouter des données dans une base de données asp.net
    Par pemco dans le forum ASP.NET
    Réponses: 5
    Dernier message: 15/08/2013, 10h05
  2. inserer les données d'une base de données dans une autres?
    Par enstein8 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 14/10/2011, 13h33
  3. ajouter des données dans une base de données
    Par khallou2007 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 01/07/2009, 15h05
  4. Réponses: 3
    Dernier message: 03/07/2008, 14h32

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo