Jump to content
tititotu

Ajouter des données dans une base SQLLite

Recommended Posts

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:

<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:

public class LitFichier extends AsyncTask<String, Void, Boolean>{
 
	private List<Livraison> lesLivraisons;
 
	@[member=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:

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:

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:

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:

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
	}
	@[member=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);
	}
	@[member=override]
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		// TODO Auto-generated method stub
	}
}

GestionBD:

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

Share this post


Link to post
Share on other sites

Bonjour,

Il y a une section développement pour ce genre de discussion, je déplace donc vers le bon endroit.

Share this post


Link to post
Share on other sites

Bonjour,

Les règles du forum demandent de ne pas faire de relance/up à moins de 24h d'intervalle, merci.

[un message supprimé]

Share this post


Link to post
Share on other sites

2eme avertissement ... pas de up/relance à moins de 24h d'inervalle.

Donc pas avant samedi midi.

La 3eme fois le sujet sera fermé, désolé.

Share this post


Link to post
Share on other sites

Bonjour,

 

Et qu'est ce que tu ne sais pas faire ? Parce que à priori tu as tous les éléments nécessaires pour le faire (parser XML, BDHelper, ...) ...

Share this post


Link to post
Share on other sites

J'ai essayer de faire comme sa mais mon programme plante:

public GestionBD(Context context) {
		monBdHelper = new BdHelper(context, "baseLivraison", null, 1);
		List<Livraison> maListe;
		maListe = new ArrayList<Livraison>();
		maListe = mesLivraisons.getLesLivraisons();
		init(maListe);
	}
	
	public void init(List<Livraison> maListeRecupereeDuFichierXML){
        for (Livraison l : maListeRecupereeDuFichierXML){
             Livraison livraisonACreer = new Livraison(); 
             livraisonACreer.setClient(l.getClient());
             livraisonACreer.setAdresse(l.getAdresse());
             long id = ajouteLivraison(livraisonACreer);
             
             
             List<Colis> listeColis = l.getLesColis();
             for (Colis c : listeColis){
                Colis colisACreer = new Colis();
                colisACreer.setRef(c.getRef());
                colisACreer.setMontant(c.getMontant());
                ajouteColis(colisACreer, id); 
              }
       }
	}

Share this post


Link to post
Share on other sites

Et quelle est l'erreur ? (stacktrace dans le LogCat ?)

Share this post


Link to post
Share on other sites

Voilà les erreurs:

05-16 05:29:02.129: E/AndroidRuntime(1162): FATAL EXCEPTION: main
05-16 05:29:02.129: E/AndroidRuntime(1162): Process: com.example.amap, PID: 1162
05-16 05:29:02.129: E/AndroidRuntime(1162): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.appli/com.example.appli.MainActivity}: java.lang.NullPointerException
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread.access$800(ActivityThread.java:135)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.os.Handler.dispatchMessage(Handler.java:102)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.os.Looper.loop(Looper.java:136)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread.main(ActivityThread.java:5017)
05-16 05:29:02.129: E/AndroidRuntime(1162): at java.lang.reflect.Method.invokeNative(Native Method)
05-16 05:29:02.129: E/AndroidRuntime(1162): at java.lang.reflect.Method.invoke(Method.java:515)
05-16 05:29:02.129: E/AndroidRuntime(1162): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
05-16 05:29:02.129: E/AndroidRuntime(1162): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
05-16 05:29:02.129: E/AndroidRuntime(1162): at dalvik.system.NativeStart.main(Native Method)
05-16 05:29:02.129: E/AndroidRuntime(1162): Caused by: java.lang.NullPointerException
05-16 05:29:02.129: E/AndroidRuntime(1162): at com.example.appli.MainActivity.onCreate(MainActivity.java:42)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.Activity.performCreate(Activity.java:5231)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
05-16 05:29:02.129: E/AndroidRuntime(1162): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
05-16 05:29:02.129: E/AndroidRuntime(1162): ... 11 more
 
Voilà mon activité principal, j'ai enlever la fonction init dans gestionBD:
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		GestionBD gestionBD = new GestionBD(this);
		gestionBD.open();
		LitFichier litFichier = new LitFichier();
		litFichier.execute("http://adIP/livraisons.xml");

		try {
			if (litFichier.get())
			{	
				MaSaxHandler mesLivraisons = null;
				List<Livraison> maListe;
				maListe = new ArrayList<Livraison>();
				maListe = mesLivraisons.getLesLivraisons();
				
				for (Livraison l : maListe){
		            Livraison livraisonACreer = new Livraison(); 
		            livraisonACreer.setClient(l.getClient());
		            livraisonACreer.setAdresse(l.getAdresse());
		            long id = gestionBD.ajouteLivraison(livraisonACreer);
		            		            
		            List<Colis> listeColis = l.getLesColis();
		            for (Colis c : listeColis){
		               Colis colisACreer = new Colis();
		               colisACreer.setRef(c.getRef());
		               colisACreer.setMontant(c.getMontant());
		               gestionBD.ajouteColis(colisACreer, id); 
		             }
		      }
				for (String ligne: litFichier.donneLivraisons())
					Log.i("lithttp",ligne);
				
				for (String ligne : gestionBD.donneLivraisons()) Log.i("lithttp", ligne);
				for (String ligne : gestionBD.donneColis()) Log.i("bd", ligne);
			}		
			else
				Log.i("litxml", "Problème lecture fichier");
		} catch (InterruptedException e) {
			Log.i("litxml", "Interruption lecture fichier");
		} catch (ExecutionException e) {
			Log.i("litxml", "Problème exécution");
		}
	}

ligne 42: maListe = mesLivraisons.getLesLivraisons();

 
Edited by tititotu

Share this post


Link to post
Share on other sites

mesLivraisons est donc à null, ce qui est normal, vu que tu la déclares et l'initialise à null 3 lignes au dessus...

Share this post


Link to post
Share on other sites

Je vien de faire comme ceci mais [color=red][b]sa[/b][/color] m'insere rien dans la base:

protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		GestionBD gestionBD = new GestionBD(this);
		gestionBD.open();
		gestionBD.supprimeColis();
		gestionBD.supprimeLivraisons();
		LitFichier litFichier = new LitFichier();
		litFichier.execute("http://192.168.1.14/livraisons.xml");
		List<Livraison> lesLivraisons;
		
		try {
			if (litFichier.get())
			{	
				MaSaxHandler mesLivraisons = new MaSaxHandler();;
				lesLivraisons = mesLivraisons.getLesLivraisons();
				
				for (Livraison l : lesLivraisons){
		            Livraison livraisonACreer = new Livraison(); 
		            livraisonACreer.setClient(l.getClient());
		            livraisonACreer.setAdresse(l.getAdresse());
		            long id = gestionBD.ajouteLivraison(livraisonACreer);
		            		            
		            List<Colis> listeColis = l.getLesColis();
		            for (Colis c : listeColis){
		               Colis colisACreer = new Colis();
		               colisACreer.setRef(c.getRef());
		               colisACreer.setMontant(c.getMontant());
		               gestionBD.ajouteColis(colisACreer, id); 
		             }
		      }
				for (String ligne: litFichier.donneLivraisons())
					Log.i("lithttp",ligne);
				
				for (String ligne : gestionBD.donneLivraisons()) Log.i("bd", ligne);
				for (String ligne : gestionBD.donneColis()) Log.i("bd", ligne);
			}		
			else
				Log.i("litxml", "Problème lecture fichier");
		} catch (InterruptedException e) {
			Log.i("litxml", "Interruption lecture fichier");
		} catch (ExecutionException e) {
			Log.i("litxml", "Problème exécution");
		}
	}

Share this post


Link to post
Share on other sites

je viens d'essayer cette solution mais j'ai toujours rien:

protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		GestionBD gestionBD = new GestionBD(this);
		gestionBD.open();
		gestionBD.supprimeColis();
		gestionBD.supprimeLivraisons();
		LitFichier litFichier = new LitFichier();
		litFichier.execute("http://192.168.1.14/livraisons.xml");

		
		try {
			if (litFichier.get())
			{	
				MaSaxHandler mesLivraisons = new MaSaxHandler();
				
				for (Livraison l : mesLivraisons.getLesLivraisons()){
		            Livraison livraisonACreer = new Livraison(); 
		            livraisonACreer.setClient(l.getClient());
		            livraisonACreer.setAdresse(l.getAdresse());
		            long id = gestionBD.ajouteLivraison(livraisonACreer);
		            		            
		            List<Colis> listeColis = l.getLesColis();
		            for (Colis c : listeColis){
		               Colis colisACreer = new Colis();
		               colisACreer.setId(id);
		               colisACreer.setRef(c.getRef());
		               colisACreer.setMontant(c.getMontant());
		               gestionBD.ajouteColis(colisACreer); 
		             }
		              
		      }
				for (String ligne: litFichier.donneLivraisons())
					Log.i("lithttp",ligne);
				
				for (String ligne : gestionBD.donneLivraisons()) Log.i("bd", ligne);
				for (String ligne : gestionBD.donneColis()) Log.i("bd", ligne);
			}		
			else
				Log.i("litxml", "Problème lecture fichier");
		} catch (InterruptedException e) {
			Log.i("litxml", "Interruption lecture fichier");
		} catch (ExecutionException e) {
			Log.i("litxml", "Problème exécution");
		}
	}

Je bloque à more et sa devient urgent car je peut pas faire la suite et j'en ai besoin pour lundi

Edited by tititotu

Share this post


Link to post
Share on other sites

Bon je remet toute mon appli parce que là je bloque et sa urge, j'en ai besoin pour lundi:

 

package XML:

classe MaSaxHandler:

public 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 http:

LitFichier:

public class LitFichier extends AsyncTask<String, Void, Boolean>{
	
	private List<Livraison> lesLivraisons;
	
	@[member=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 métier:

classe livraison:

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 + "\n"+unColis.toString();		
		}
		return chaine;
	}
}

classe colis:

public class Colis {
	
	private String ref;
	private double montant=0;
	private long idLivraison;
	
	public Colis(long idLivraison, double montant, String ref) {
		super();
		this.idLivraison = idLivraison;
		this.montant = montant;
		this.ref = ref;
	}
	
	public Colis(){
		super();
	}
	
	public double getMontant() {
		return montant;
	}
	
	public long getIdLivraison() {
		return idLivraison;
	}
	
	public String getRef(){
		return ref;
	}
	
	public void setId(long id){
		this.idLivraison = id;
	}
	
	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;
	}
}

classe GestionBD:

public class GestionBD {
	private SQLiteDatabase maBase;
	private BdHelper monBdHelper;
	
	public GestionBD(Context context) {
		
		monBdHelper = new BdHelper(context, "baseLivraison", null, 1);
	}
	
	public void init(){
		open();
		
		MaSaxHandler mesLivraisons = new MaSaxHandler();
		
		for (Livraison l : mesLivraisons.getLesLivraisons()){
            Livraison livraisonACreer = new Livraison(); 
            livraisonACreer.setClient(l.getClient());
            livraisonACreer.setAdresse(l.getAdresse());
            long id;
            id = ajouteLivraison(livraisonACreer);
            		            
            List<Colis> listeColis = l.getLesColis();
            for (Colis c : listeColis){
               Colis colisACreer = new Colis();
               colisACreer.setId(id);
               colisACreer.setRef(c.getRef());
               colisACreer.setMontant(c.getMontant());
               ajouteColis(colisACreer); 
             }
              
      }
		
		
	}
	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){
		ContentValues v = new ContentValues();
		v.put("idlivraison", colis.getIdLivraison());
		v.put("ref", colis.getRef());
		v.put("montant", colis.getMontant());
		maBase.insert("colis", null, v);
	}
	

	public void supprimeLivraisons(){
		maBase.delete("livraison", null, null);
	}
	
	public void supprimeColis(){
		maBase.delete("colis", 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;
	}
}

classe BDHelper:

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
	}
	@[member=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);
	}
	
		
	@[member=override]
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		// TODO Auto-generated method stub
	}
}

Mon activité principal:

public class MainActivity extends ActionBarActivity {

	@[member=override]
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		GestionBD gestionBD = new GestionBD(this);
		

		LitFichier litFichier = new LitFichier();
		litFichier.execute("http://adresseIP/livraisons.xml");

		
		
		
		
		
		try {
			if (litFichier.get())
			{	
				gestionBD.init();
				for (String ligne : gestionBD.donneLivraisons()) Log.i("bd", ligne);
				for (String ligne : gestionBD.donneColis()) Log.i("bd", ligne);
				for (String ligne: litFichier.donneLivraisons())
					Log.i("lithttp",ligne);
				

			}		
			else
				Log.i("litxml", "Problème lecture fichier");
		} catch (InterruptedException e) {
			Log.i("litxml", "Interruption lecture fichier");
		} catch (ExecutionException e) {
			Log.i("litxml", "Problème exécution");
		}
	}

	@[member=override]
	public boolean onCreateOptionsMenu(Menu menu) {

		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@[member=override]
	public boolean onOptionsItemSelected(MenuItem item) {
		// Handle action bar item clicks here. The action bar will
		// automatically handle clicks on the Home/Up button, so long
		// as you specify a parent activity in AndroidManifest.xml.
		int id = item.getItemId();
		if (id == R.id.action_settings) {
			return true;
		}
		return super.onOptionsItemSelected(item);
	}

	/**
	 * A placeholder fragment containing a simple view.
	 */
	public static class PlaceholderFragment extends Fragment {

		public PlaceholderFragment() {
		}

		@[member=override]
		public View onCreateView(LayoutInflater inflater, ViewGroup container,
				Bundle savedInstanceState) {
			View rootView = inflater.inflate(R.layout.fragment_main, container,
					false);
			return rootView;
		}
	}

}

Voilà vous avez toute mon appli

Share this post


Link to post
Share on other sites

Peut-être que personne (à commencer par moi) ne comprend vraiment ce que tu veux faire / le(s) problème(s) que tu rencontres... Balancer tout le code de ton appli (en espérant qu'on le corrige pour toi ?) ne suffit pas. Essaye d'être un peu plus précis, et d'isoler où le problème se situe (en t'aidant du debugger / en mettant des logs). Est-ce un problème réseau ? ou bien récupère-tu bien le XML et c'est alors un pb de parsing dudit XML ? ou bien c'est l'insertion d'un élément dans la base au final ??

Merci

  • Like 1

Share this post


Link to post
Share on other sites

J'arrive bien à lire le fichier et à récupérer ces données puisque le log http me les affiche bien. Mon problème c'est l'ajout dans la base de données

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.






×
×
  • Create New...