2014-01-04 2 views
2

Я работаю над проектом, в котором 6 полей edittext вставляются в базу данных, когда я нажимаю кнопку «Сохранить», и она будет просматриваться в списке ... Я могу способный достичь этих целей, но проблема в том, что я не смог вставить несколько строк в БД. В представлении списка всегда отображаются только первые вставленные значения, но если я снова вставляю их. Пожалуйста, помогите мне для этого решения ....
Мой код для создания таблицы и вставки следующим образом для вашей справки
не может вставить несколько строк в android SQLite DB

public void onCreate(SQLiteDatabase db) { 
      // TODO Auto-generated method stub 
      String CREATE_TABLE_QUERY = null; 
      // Used 
      CREATE_TABLE_QUERY = "CREATE TABLE IF NOT EXISTS userMaster(Bar CHAR(25),Product CHAR(15), Name TEXT,Mrp CHAR(15),Quantity CHAR(15), Tax CHAR(15));"; 
      db.execSQL(CREATE_TABLE_QUERY); 
      L.i("userMaster Table created"); 

     } 

     public void insertDetails(String bar, String mrp, String quantity, 
       String tax, String product, String name) { 
      SQLiteDatabase dbase = this.getReadableDatabase(); 
      ContentValues cv = new ContentValues(); 
      cv.put("bar", bar); 
      cv.put("product", product); 
      cv.put("name", name); 

      cv.put("mrp", mrp); 
      cv.put("quantity", quantity); 
      cv.put("tax", tax); 

      dbase.insert("userMaster", null, cv); 
      dbase.close(); 
     } <br> 
public void insertUserMaster(String bar, String mrp, String quantity, 
      String tax, String product, String name) { 

     SQLiteDatabase SqlDB = getWritableDatabase(); 

     SqlDB.delete("userMaster", null, null); 

     String INSERT = "insert into userMaster (Bar,Product,Name,Mrp,Quantity,Tax) values (?,?,?,?,?,?)"; 
     SQLiteStatement insertstatment = SqlDB.compileStatement(INSERT); 
     insertstatment.bindString(1, bar); 
     insertstatment.bindString(2, product); 
     insertstatment.bindString(3, name); 
     insertstatment.bindString(4, quantity); 
     insertstatment.bindString(5, mrp); 
     insertstatment.bindString(6, tax); 
     insertstatment.executeInsert(); 
     SqlDB.close(); 
     close(); 

    } <br> 

Представление списка массива следующим образом

public ArrayList<HashMap<String, String>> getdata() { 
     SQLiteDatabase db = this.getReadableDatabase(); 

     Cursor cursor = db.query("userMaster", null, null, null, null, null, 
       null, null); 
     ArrayList<HashMap<String, String>> arraylist = new ArrayList<HashMap<String, String>>(); 
     if (cursor != null) { 
      if (cursor.getCount() > 0 && cursor.moveToFirst()) { 
       do { 
        HashMap<String, String> hm = new HashMap<String, String>(); 

        hm.put("bar", cursor.getString(0)); 
        hm.put("product", cursor.getString(1)); 
        hm.put("name", cursor.getString(2)); 
        hm.put("mrp", cursor.getString(3)); 
        hm.put("quantity", cursor.getString(4)); 
        hm.put("tax", cursor.getString(5)); 
        arraylist.add(hm); 
       } while (cursor.moveToNext()); 
      } 

     } 

     cursor.close(); 
     db.close(); 

     return arraylist; 

    } 

ответ

0

Используйте правильный запрос, чтобы избежать этого вопроса. Перед установкой проверьте, удаляете ли вы существующую таблицу.

0

В методе insertUserMaster вы удаляете все данные перед вставкой.

Удалить эту строку:

SqlDB.delete("userMaster", null, null); 
+0

все еще не может вставить вторую строку в БД, хотя я сделал то, что вы сказали –

+0

Если вы используете ListView для отображения содержимого базы данных, вы должны иметь столбец с именем _id , Приведенный код не показывает, как объявлен адаптер. Я предлагаю вам прочитать [this] (http://www.vogella.com/tutorials/AndroidListView/article.html), чтобы узнать, как использовать sqlite и ListView. – ramaral

+0

Спасибо, что получил !!! –

Смежные вопросы