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 des données dans une base SQL Lite


Sujet :

Android

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    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
    Par défaut ajouter des données dans une base SQL Lite
    Bonjour,

    Je réalise une appli Android avec un fichier XML que je lit et souhaiterait ajouter les données de ce fichier dans une base SQLite. j'ai donc préparé tout mes script mais là bloque pour l'insertion, je ne vois pas trop comment faire:
    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>
    Package http:
    Lithttp:
    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
    public class LitFichier extends AsyncTask<String, Void, Boolean>{
     
    	private List<Livraison> lesLivraisons;
     
    	@Override
    	protected Boolean doInBackground(String... urls) {
    		URL url;
    		try {
    			url = new URL(urls[0]);
    			MaSaxHandler handler = new MaSaxHandler();
    			InputStream inputStream;
    			inputStream = url.openConnection().getInputStream();
     
    			handler.parse(inputStream);
    	        lesLivraisons = handler.getLesLivraisons();
     
    	        return true;
    		} catch (MalformedURLException e) {
    			return false;
    		} catch (IOException e) {
    			return false;
    		} catch (ParserConfigurationException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		} catch (SAXException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}
    		return null;
    	}
     
    	public List<String> donneLivraisons(){
    		List<String> liste = new ArrayList<String>();
    		for (Livraison livraison : lesLivraisons)
    			liste.add(livraison.toString());
    		return liste;
    	}
    }
    Package xml:
    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
    ublic class MaSaxHandler extends DefaultHandler {
     
    	   private Livraison livraison;
    	   private List<Livraison> lesLivraisons = new ArrayList<Livraison>();
    	   private Colis 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")){
    	        	livraison.addColis(colis);
    	        }else if (localName.equals("ref")){
    	        	colis.setRef(valeur);
    	        }else if (localName.equals("montant")){
    	        	double monLong= Double.parseDouble(valeur);
    	        	colis.setMontant(monLong);
    	        }
    	    }
    	   public List<Livraison> getLesLivraisons() {
    		   return lesLivraisons;
    	   }
    }
    package métier:
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    public class Livraison {
     
    	private String client;
    	private String adresse;
    	private List<Colis> lesColis;
     
    	public Livraison(String client, String adresse) {
    		this.client = client;
    		this.adresse = adresse;
    	}
     
    	public Livraison(){
    		super();
    		lesColis = new ArrayList<Colis>();
    	}
     
    	public String getClient(){
    		return client;
    	}
     
    	public String getAdresse(){
    		return adresse;
    	}
     
    	public List<Colis> getLesColis(){
    		return lesColis;
    	}
     
    	public void setLesColis(List<Colis> lesColis){
    		this.lesColis = lesColis;
    	}
     
    	public void setClient(String client) {
    		this.client = client;
    	}
     
    	public void setAdresse(String adresse) {
    		this.adresse = adresse;
    	}
     
    	public void addColis(Colis unColis){
    		lesColis.add(unColis);
    	}
     
    	public String toString(){
    		String chaine = "Livraison : client : "+client+" => adresse : "+adresse+" \nLes colis :";
    		for (Colis unColis : lesColis){
    			chaine = chaine + "\nRéférence : "+unColis.getRef()+ " => montant : "+unColis.getMontant();
    		}
    		return chaine;
    	}
    }
    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(double montant) {
    		this.montant = montant;
    	}
     
    	public String toString(){
    		return "Colis : référence : "+ref+" => montant : "+montant;
    	}
    }
    BDHelper:
    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
    	}
    }
    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;
    	}
    }
    Merci de votre aide

  2. #2
    Membre éprouvé
    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
    Par défaut
    Personne?

  3. #3
    Traductrice
    Avatar de Mishulyna
    Femme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2008
    Messages
    1 505
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2008
    Messages : 1 505
    Par défaut
    Bonjour,

    Ca m'écœure, parole d'honneur!

    Lors d'une autre discussion vous arriviez à afficher les objets, où est-ce que ça gêne pour insérer dans une base de données des objets auxquels on peut accéder pour les afficher?
    Théoriquement, il faudrait vérifier dans la DB si l'objet existe, si ce n'est pas le cas: le créer, puis insérer les objets dépendants. Si l'objet existe: le mettre à jour si besoin, puis insérer les objets dépendants (vérifier s'ils existent, etc. etc.).

    Si c'était que du "simple" Java: j'aurais dit que vous n'avez qu'à dé-sérialiser la liste d'objets de votre fichier .xml pour l'utiliser. Pour une application Android (jamais fait), j'utiliserais plutôt une sérialisation en JSON mais ça n'a aucun rapport avec votre problème. Sachez que je lis vos questions, je compatis mais je ne sais pas vous aider...

  4. #4
    Membre éprouvé
    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
    Par défaut
    Je bloque pour l'insertion des objets, j'arrive pas à récupérer ce que j'ai lu pour le mettre dans ma fonction init qui va faire les ajouts dans la base.
    Mes objets, je l'ai ai bien récupéré puisque je l'ai ai affiché

  5. #5
    Traductrice
    Avatar de Mishulyna
    Femme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2008
    Messages
    1 505
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2008
    Messages : 1 505
    Par défaut
    Ben, puisque apparemment on sait pas faire quoi que ce soit sans avoir un Colis "valide", pour chaque objet Livraison: insérer d'abord le(s) Colis, puis la Livraison, avec ses String client et String adresse.

  6. #6
    Membre éprouvé
    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
    Par défaut
    Sauf que Colis à une référence à Livraison
    Un client peut avoir plusieurs Colis donc clé étrangère de Livraison dans Colis

+ Répondre à la discussion
Cette discussion est résolue.

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. [Débutant] Enregistrer des données dans une base sql server CE
    Par hugnka dans le forum VB.NET
    Réponses: 11
    Dernier message: 18/12/2012, 15h47
  3. Réponses: 4
    Dernier message: 11/03/2011, 14h45
  4. 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

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